:root,[data-theme="light"]{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-tertiary:#f1f5f9;--text-primary:#1e293b;--text-secondary:#64748b;--text-muted:#94a3b8;--border-color:#e2e8f0;--border-light:#f1f5f9;--accent:#e67e22;--accent-hover:#d35400;--accent-light:#fef3e2;--accent-text:#fff;--danger:#dc2626;--danger-hover:#b91c1c;--success:#10b981;--success-light:#d1fae5;--warning:#f59e0b;--shadow-sm:0 1px 3px rgba(30,41,59,.06);--shadow-md:0 4px 12px rgba(30,41,59,.08);--shadow-lg:0 10px 30px rgba(30,41,59,.1);--navbar-bg:#1e293b;--navbar-text:#cbd5e1;--card-bg:#fff;--input-bg:#fff;--input-border:#cbd5e1;--overlay:rgba(30,41,59,.5);--radius:12px;--radius-sm:8px;--focus-ring:0 0 0 3px rgba(230,126,34,.25)}
[data-theme="dark"]{--bg-primary:#0f1117;--bg-secondary:#181a23;--bg-tertiary:#1f2231;--text-primary:#e2e8f0;--text-secondary:#94a3b8;--text-muted:#64748b;--border-color:#2a2d3a;--border-light:#1f2231;--accent:#e67e22;--accent-hover:#f0923e;--accent-light:#3d2a14;--accent-text:#fff;--danger:#ef4444;--danger-hover:#f87171;--success:#10b981;--success-light:#0a2e1f;--warning:#f59e0b;--shadow-sm:0 1px 3px rgba(0,0,0,.3);--shadow-md:0 4px 12px rgba(0,0,0,.4);--shadow-lg:0 10px 30px rgba(0,0,0,.5);--navbar-bg:#0a0c12;--navbar-text:#94a3b8;--card-bg:#181a23;--input-bg:#1f2231;--input-border:#333749;--overlay:rgba(0,0,0,.7)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:18px}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.7;min-height:100vh;-webkit-text-size-adjust:100%}
a{color:var(--accent);text-decoration:none;transition:color .2s}a:hover{color:var(--accent-hover)}
hr{border:none;border-top:1px solid var(--border-color);margin:1.5rem 0}

.navbar{background:var(--navbar-bg);color:var(--navbar-text);padding:0 1.25rem;position:sticky;top:0;z-index:1000;box-shadow:var(--shadow-md)}
.nav-container{max-width:1600px;margin:0 auto;display:flex;align-items:center;height:64px;gap:1.5rem}
.nav-brand{font-size:1.4rem;font-weight:700;color:#fff;display:flex;align-items:center;gap:.5rem;white-space:nowrap}
.nav-brand i{color:var(--accent);font-size:1.2rem}
.nav-links{display:flex;align-items:center;gap:.5rem;flex:1}
.nav-link{color:var(--navbar-text);padding:.6rem .9rem;border-radius:var(--radius-sm);font-size:.95rem;transition:background .2s;display:flex;align-items:center;gap:.5rem;white-space:nowrap}
.nav-link:hover{background:rgba(255,255,255,.1);color:#fff}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:.75rem}
.nav-toggle{display:none;background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.5rem;min-width:48px;min-height:48px;align-items:center;justify-content:center}
.nav-user-menu{position:relative}
.nav-user-btn{background:none;border:1px solid rgba(255,255,255,.15);color:var(--navbar-text);padding:.5rem .9rem;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;gap:.5rem;font-size:.9rem;min-height:44px}
.nav-user-btn:hover{background:rgba(255,255,255,.08)}
.nav-dropdown{display:none;position:absolute;right:0;top:100%;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);min-width:180px;z-index:1001;margin-top:4px}
.nav-user-menu:hover .nav-dropdown{display:block}
.nav-dropdown a{display:flex;align-items:center;gap:.6rem;padding:.75rem 1.1rem;color:var(--text-primary);font-size:.95rem;min-height:48px}
.nav-dropdown a:hover{background:var(--bg-tertiary)}
.theme-toggle{background:none;border:1px solid rgba(255,255,255,.15);color:var(--navbar-text);width:44px;height:44px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;font-size:1.1rem}
.theme-toggle:hover{background:rgba(255,255,255,.1)}
[data-theme="light"] .theme-icon-light{display:none}[data-theme="dark"] .theme-icon-dark{display:none}

.main-content{padding-bottom:2rem}.container{max-width:1200px;margin:0 auto;padding:1.5rem 1.25rem}.container-fluid{padding:1.25rem}
.page-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}
.page-header h1{font-size:1.5rem;font-weight:700}.page-header h1 small{font-weight:400;color:var(--text-secondary);font-size:.65em}
.card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.card-body{padding:1.75rem}

.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.65rem 1.2rem;border:1px solid transparent;border-radius:var(--radius-sm);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none;white-space:nowrap;font-family:inherit;min-height:48px;line-height:1.4}
.btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}
.btn-primary{background:var(--accent);color:var(--accent-text)}.btn-primary:hover{background:var(--accent-hover);color:var(--accent-text)}
.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color)}.btn-secondary:hover{background:var(--border-color);color:var(--text-primary)}
.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:var(--danger-hover)}
.btn-outline{background:transparent;color:var(--text-secondary);border-color:var(--border-color)}.btn-outline:hover,.btn-outline.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-sm{padding:.45rem .85rem;font-size:.85rem;min-height:40px}.btn-xs{padding:.35rem .65rem;font-size:.8rem;min-height:36px}
.btn-lg{padding:.8rem 1.75rem;font-size:1.05rem;min-height:52px}.btn-block{width:100%;justify-content:center}

.form-group{margin-bottom:1.15rem}.form-group label{display:block;font-size:.9rem;font-weight:600;color:var(--text-secondary);margin-bottom:.4rem}
.form-control{width:100%;padding:.7rem .9rem;border:1px solid var(--input-border);border-radius:var(--radius-sm);background:var(--input-bg);color:var(--text-primary);font-size:1rem;font-family:inherit;transition:border-color .2s,box-shadow .2s;min-height:48px}
.form-control:focus{outline:none;border-color:var(--accent);box-shadow:var(--focus-ring)}
.form-control-sm{padding:.5rem .75rem;font-size:.9rem;min-height:42px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-actions{display:flex;gap:.75rem;margin-top:1.75rem}
.help-text{font-size:.85rem;color:var(--text-muted);margin-top:.3rem;display:block}
.input-group{display:flex;gap:0}.input-group .form-control{border-top-right-radius:0;border-bottom-right-radius:0}.input-group .btn{border-top-left-radius:0;border-bottom-left-radius:0}
select.form-control{cursor:pointer}textarea.form-control{resize:vertical;min-height:100px}

.alert{padding:.85rem 1.1rem;border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.95rem;display:flex;align-items:center;gap:.5rem}
.alert-danger{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}[data-theme="dark"] .alert-danger{background:#3f1212;color:#fca5a5;border-color:#5a1a1a}

.trip-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:1.25rem}
.trip-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:box-shadow .25s,transform .25s}
.trip-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.trip-card-header{padding:1.1rem 1.4rem 0}.trip-card-body{padding:.5rem 1.4rem 1.1rem;flex:1}
.trip-card-body h3{font-size:1.15rem;margin-bottom:.35rem}.trip-card-body h3 a{color:var(--text-primary)}.trip-card-body h3 a:hover{color:var(--accent)}
.trip-desc{color:var(--text-secondary);font-size:.9rem;margin-bottom:.6rem}
.trip-meta{display:flex;flex-wrap:wrap;gap:.85rem;font-size:.85rem;color:var(--text-muted)}.trip-meta i{margin-right:.25rem}
.trip-card-footer{padding:.85rem 1.4rem;border-top:1px solid var(--border-light);display:flex;gap:.6rem}
.trip-status{display:inline-block;padding:.2rem .7rem;border-radius:999px;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.status-planned{background:#fef3e2;color:#b45309;border:1px solid #fcd9a0}.status-active{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.status-completed{background:#e0e7ff;color:#3730a3;border:1px solid #c7d2fe}
[data-theme="dark"] .status-planned{background:#3d2a14;color:#fbbf24;border-color:#5c3d16}[data-theme="dark"] .status-active{background:#0a2e1f;color:#34d399;border-color:#134e35}[data-theme="dark"] .status-completed{background:#1e1b4b;color:#a5b4fc;border-color:#312e81}

.empty-state{text-align:center;padding:3.5rem 1.25rem;color:var(--text-muted)}.empty-state i{margin-bottom:1rem;opacity:.35;color:var(--accent)}
.empty-state h2,.empty-state h3{color:var(--text-secondary);margin-bottom:.5rem}.empty-state p{margin-bottom:1.75rem;font-size:1rem}

.trip-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.1rem;flex-wrap:wrap}
.trip-header h1{font-size:1.45rem}.trip-header-actions{display:flex;gap:.6rem;flex-wrap:wrap}
.trip-desc-full{color:var(--text-secondary);font-size:.95rem;margin-top:.3rem}

.stats-bar{display:flex;gap:0;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius);margin-bottom:1.1rem;box-shadow:var(--shadow-sm);overflow:hidden}
.stat{flex:1;text-align:center;padding:.9rem .5rem;border-right:1px solid var(--border-light)}.stat:last-child{border-right:none}
.stat-value{font-size:1.5rem;font-weight:700;color:var(--accent)}.stat-label{font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}

.map-layout{display:flex;gap:0;border:1px solid var(--border-color);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:1.5rem;height:520px}
.map-sidebar{width:290px;min-width:290px;background:var(--card-bg);border-right:1px solid var(--border-color);overflow-y:auto;padding:1.1rem;transition:margin-left .3s}
.map-sidebar.collapsed{margin-left:-290px}.map-container{flex:1;position:relative}.trip-map{width:100%;height:100%}
.sidebar-toggle{position:absolute;top:10px;left:10px;z-index:999;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-sm);width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-sm);color:var(--text-primary);font-size:1.1rem}
.map-export-bar{position:absolute;top:10px;right:10px;z-index:999;display:flex;gap:6px;flex-direction:column}
.map-export-bar .btn{min-height:40px;font-size:.82rem;padding:.35rem .7rem;background:var(--card-bg);color:var(--text-primary);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}
.map-export-bar .btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

.sidebar-section{margin-bottom:1.1rem}.sidebar-section h4{font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:.6rem;font-weight:700}
.filter-group{margin-bottom:.85rem}.filter-group>label{font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:.35rem;display:block}
.quick-filters{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.5rem}
.category-filters{display:flex;flex-direction:column;gap:.4rem}
.category-check{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.88rem;min-height:36px}
.category-check input[type="checkbox"]{width:20px;height:20px;cursor:pointer;accent-color:var(--accent)}
.cat-badge{padding:.2rem .6rem;border-radius:999px;font-size:.8rem;font-weight:500;display:inline-flex;align-items:center;gap:.35rem}

.entries-section{margin-top:1.25rem}.entries-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.1rem}
.entries-header h2{font-size:1.25rem}.entries-timeline{display:flex;flex-direction:column;gap:.6rem}
.timeline-date{font-size:.95rem;font-weight:700;color:var(--accent);padding:.6rem 0;border-bottom:2px solid var(--accent);margin-top:.85rem}
.timeline-date:first-child{margin-top:0}.timeline-date i{margin-right:.35rem}
.entry-card{display:flex;gap:.85rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius);padding:1rem 1.15rem;transition:box-shadow .2s}
.entry-card:hover{box-shadow:var(--shadow-sm)}
.entry-marker{width:40px;height:40px;min-width:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.95rem;margin-top:.15rem}
.entry-content{flex:1;min-width:0}.entry-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}
.entry-top h4{font-size:1.02rem;font-weight:600}.entry-category{font-size:.8rem;color:var(--text-muted);font-weight:400;margin-left:.4rem}
.entry-actions{display:flex;gap:.3rem;flex-shrink:0}
.entry-details{display:flex;flex-wrap:wrap;gap:.7rem;font-size:.85rem;color:var(--text-muted);margin-top:.3rem}.entry-details i{margin-right:.2rem}
.leg-miles{color:var(--success);font-weight:600}.entry-notes{color:var(--text-secondary);font-size:.92rem;margin-top:.45rem;line-height:1.6}
.entry-photos{display:flex;gap:.6rem;margin-top:.6rem;flex-wrap:wrap}
.entry-thumb img{width:90px;height:62px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border-color);transition:transform .2s}
.entry-thumb img:hover{transform:scale(1.05)}
.entry-weather{font-size:.82rem;color:var(--text-muted);display:flex;align-items:center;gap:.3rem}
.entry-rating{display:flex;align-items:center;gap:.2rem;color:var(--warning);font-size:.9rem}

.entry-form-layout{max-width:850px}.entry-form-card{margin-bottom:2rem}
.location-methods{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.85rem}
.location-panel{margin-bottom:.85rem}.location-panel.hidden{display:none}
.entry-map{height:300px;border-radius:var(--radius-sm);border:1px solid var(--border-color);margin-bottom:1.1rem}
.search-results{max-height:220px;overflow-y:auto;margin-top:.4rem}
.search-result-item{padding:.65rem .85rem;cursor:pointer;font-size:.9rem;border-bottom:1px solid var(--border-light);transition:background .15s;min-height:44px;display:flex;align-items:center}
.search-result-item:hover{background:var(--bg-tertiary)}
.existing-photos{display:flex;gap:.6rem;flex-wrap:wrap}.existing-photo{position:relative}
.existing-photo img{width:110px;height:75px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border-color)}
.existing-photo .btn{position:absolute;top:4px;right:4px}
.photo-preview{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.6rem}
.photo-preview img{width:110px;height:75px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border-color)}

/* Rating tags */
.rating-stars{display:flex;gap:.3rem;font-size:1.3rem}.rating-stars i{cursor:pointer;color:var(--border-color);transition:color .15s}
.rating-stars i.active,.rating-stars i:hover{color:var(--warning)}
.rating-tags-grid{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}
.rating-tag{padding:.3rem .7rem;border:1px solid var(--border-color);border-radius:999px;font-size:.82rem;cursor:pointer;transition:all .15s;min-height:36px;display:flex;align-items:center}
.rating-tag.selected{background:var(--accent);color:#fff;border-color:var(--accent)}

/* Quick Log FAB */
.quick-log-fab{position:fixed;bottom:24px;right:24px;z-index:900;width:64px;height:64px;border-radius:50%;background:var(--accent);color:#fff;border:none;font-size:1.5rem;cursor:pointer;box-shadow:0 4px 16px rgba(230,126,34,.4);display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s}
.quick-log-fab:hover{transform:scale(1.1);box-shadow:0 6px 24px rgba(230,126,34,.5)}
.quick-log-modal{position:fixed;bottom:100px;right:16px;z-index:901;width:340px;max-width:calc(100vw - 32px);background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:1.25rem;display:none}
.quick-log-modal.open{display:block}
.quick-log-modal h3{font-size:1.05rem;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}
.ql-categories{display:grid;grid-template-columns:repeat(5,1fr);gap:.4rem;margin-bottom:.75rem}
.ql-cat{width:100%;aspect-ratio:1;border-radius:var(--radius-sm);border:2px solid var(--border-color);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;font-size:.65rem;gap:.2rem;transition:all .15s;background:var(--bg-tertiary)}
.ql-cat i{font-size:1.1rem}.ql-cat.selected{border-color:var(--accent);background:var(--accent-light)}
.ql-status{font-size:.82rem;color:var(--text-muted);margin-top:.3rem}

/* Login */
.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#1e293b,#0f172a,#1a1523)}
.login-container{width:100%;max-width:420px;padding:1.25rem}
.login-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:2.25rem}
.login-header{text-align:center;margin-bottom:1.75rem}.login-header i{font-size:2.75rem;color:#e67e22;margin-bottom:.5rem}
.login-header h1{font-size:1.6rem;color:#1e293b}.login-header p{color:#64748b;font-size:.95rem}
.login-form .form-group{margin-bottom:1.35rem}.login-form label{color:#475569}
.login-form .form-control{padding:.8rem .95rem;font-size:1.05rem}

/* Popups */
.leaflet-popup-content-wrapper{border-radius:var(--radius-sm)!important;box-shadow:var(--shadow-md)!important;font-size:.95rem!important}
.leaflet-popup-content{margin:.85rem!important;line-height:1.6}
.popup-title{font-weight:700;font-size:1.02rem;margin-bottom:.35rem}.popup-meta{color:#64748b;font-size:.85rem;margin-bottom:.25rem}
.popup-notes{margin-top:.35rem;font-size:.9rem}.popup-photos{display:flex;gap:.4rem;margin-top:.5rem}
.popup-photos img{width:70px;height:50px;object-fit:cover;border-radius:6px}

/* Export overlay */
.export-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--overlay);z-index:10000;display:flex;align-items:center;justify-content:center}
.export-modal{background:var(--card-bg);border-radius:var(--radius);padding:2rem;max-width:500px;width:90%;box-shadow:var(--shadow-lg)}
.export-modal h3{margin-bottom:1rem;font-size:1.2rem}.export-options{display:flex;flex-direction:column;gap:.6rem}
.export-option{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;min-height:56px;font-size:.95rem}
.export-option:hover{border-color:var(--accent);background:var(--accent-light)}.export-option i{font-size:1.2rem;color:var(--accent);width:28px;text-align:center}

/* Share badge */
.share-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.15rem .5rem;border-radius:999px;font-size:.72rem;font-weight:600;background:var(--accent-light);color:var(--accent)}

/* Public page */
.public-page{min-height:100vh;background:var(--bg-primary)}
.public-header{background:var(--navbar-bg);color:#fff;padding:1.25rem 1.5rem}
.public-header h1{font-size:1.3rem;font-weight:700}.public-header .brand{color:var(--accent);font-size:.85rem}

/* Responsive */
@media(max-width:768px){
html{font-size:17px}
.nav-links{display:none;position:fixed;top:64px;left:0;right:0;background:var(--navbar-bg);flex-direction:column;padding:1.1rem;gap:.35rem;box-shadow:var(--shadow-lg);z-index:999}
.nav-links.open{display:flex}.nav-right{margin-left:0}.nav-toggle{display:flex;margin-left:auto}.nav-link{min-height:48px;font-size:1rem}
.page-header{flex-direction:column;align-items:flex-start}.trip-grid{grid-template-columns:1fr}.form-row{grid-template-columns:1fr}
.stats-bar{flex-wrap:wrap}.stat{min-width:33%}
.map-layout{flex-direction:column;height:auto}.map-sidebar{width:100%;min-width:unset;border-right:none;border-bottom:1px solid var(--border-color);max-height:320px}
.map-sidebar.collapsed{display:none}.trip-map{height:380px}
.trip-header{flex-direction:column}.trip-header-actions{width:100%}.trip-header-actions .btn{flex:1;justify-content:center}
.location-methods .btn{flex:1;min-width:0;justify-content:center}
.map-export-bar{flex-direction:row;top:auto;bottom:10px;right:10px}
.quick-log-modal{right:8px;left:8px;width:auto;bottom:96px}
}
@media(max-width:480px){html{font-size:16px}.stats-bar{flex-wrap:wrap}.stat{flex:1 1 45%;min-width:45%}.entry-card{flex-direction:column}.entry-marker{width:34px;height:34px;min-width:34px;font-size:.85rem}}
.text-center{text-align:center}.text-muted{color:var(--text-muted)}
