:root{--green: #4a6741;--green-dark: #354d2f;--brown: #8b6347;--brown-dark: #6b4a31;--cream: #f5f0e8;--cream-dark: #ede5d8;--text: #2c2c2c;--text-muted: #666;--white: #ffffff;--shadow: 0 2px 12px rgba(0,0,0,.1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,system-ui,sans-serif;color:var(--text);background:var(--cream);line-height:1.6}a{text-decoration:none;color:inherit}header{background:var(--white);box-shadow:var(--shadow);position:sticky;top:0;z-index:100}.navbar{max-width:1200px;margin:0 auto;padding:.75rem 2rem;display:flex;align-items:center;gap:2rem}.brand{display:inline-flex;height:52px;overflow:hidden;align-items:center}.logo{height:104px;width:auto}.nav-links{display:flex;list-style:none;gap:1.75rem;margin-left:1rem;flex:1}.nav-links a{font-weight:500;color:var(--text-muted);transition:color .2s}.nav-links a:hover{color:var(--green)}.btn-primary{background:var(--green);color:var(--white);padding:.6rem 1.4rem;border-radius:6px;font-weight:600;transition:background .2s;white-space:nowrap}.btn-primary:hover{background:var(--green-dark)}.btn-secondary{background:transparent;color:var(--white);padding:.6rem 1.4rem;border-radius:6px;font-weight:600;border:2px solid rgba(255,255,255,.7);transition:background .2s,border-color .2s}.btn-secondary:hover{background:#ffffff26;border-color:var(--white)}.btn-large{padding:.85rem 2rem;font-size:1.05rem}.hero{position:relative;background:linear-gradient(to bottom,#354d2fa6,#6b4a318c),url(https://images.unsplash.com/photo-1522163182402-834f871fd851?w=1600&q=80) center/cover no-repeat;min-height:520px;display:flex;align-items:center;padding:4rem 2rem}.hero-content{max-width:1200px;margin:0 auto;width:100%;color:var(--white)}.hero-content h1{font-size:clamp(2.2rem,5vw,3.5rem);font-weight:800;line-height:1.15;margin-bottom:1rem;text-shadow:0 2px 8px rgba(0,0,0,.3)}.hero-content p{font-size:1.2rem;max-width:520px;margin-bottom:2rem;opacity:.92;text-shadow:0 1px 4px rgba(0,0,0,.3)}.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}.section{padding:5rem 2rem}.container{max-width:1200px;margin:0 auto}.section-title{font-size:1.9rem;font-weight:700;color:var(--green-dark);margin-bottom:2.5rem;text-align:center}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.card{background:var(--white);border-radius:10px;padding:1.5rem;box-shadow:var(--shadow);position:relative;transition:transform .2s,box-shadow .2s}.card:hover{transform:translateY(-3px);box-shadow:0 6px 20px #00000021}.card-badge{display:inline-block;padding:.2rem .7rem;border-radius:20px;font-size:.72rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:.75rem}.card-badge.good{background:#d4edda;color:#2d6a3f}.card-badge.moderate{background:#fff3cd;color:#856404}.card-badge.poor{background:#f8d7da;color:#842029}.card h3{font-size:1.15rem;font-weight:700;color:var(--green-dark);margin-bottom:.1rem}.location{font-size:.82rem;color:var(--text-muted);margin-bottom:1rem}.condition-row{display:flex;align-items:center;gap:.5rem;font-size:.9rem;margin-bottom:.4rem;color:var(--text)}.cond-icon{font-size:1rem;width:1.4rem;text-align:center}.card-link{display:inline-block;margin-top:1rem;font-size:.88rem;font-weight:600;color:var(--brown);transition:color .2s}.card-link:hover{color:var(--brown-dark)}.features-section{background:var(--cream-dark)}.features-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:2rem}.feature{text-align:center;padding:2rem 1.5rem;background:var(--white);border-radius:10px;box-shadow:var(--shadow)}.feature-icon{font-size:2.4rem;margin-bottom:1rem}.feature h3{font-size:1.1rem;font-weight:700;color:var(--green-dark);margin-bottom:.5rem}.feature p{font-size:.92rem;color:var(--text-muted);line-height:1.6}.cta-section{background:var(--green);padding:5rem 2rem;text-align:center;color:var(--white)}.cta-content h2{font-size:2rem;font-weight:800;margin-bottom:.75rem}.cta-content p{font-size:1.1rem;opacity:.88;margin-bottom:2rem}footer{background:var(--text);color:#ffffffb3;padding:3rem 2rem;text-align:center}.footer-logo{height:60px;width:auto;margin-bottom:.5rem;filter:brightness(0) invert(1);opacity:.85}.footer-tagline{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;opacity:.55;margin-bottom:1.5rem}.footer-links{display:flex;justify-content:center;gap:2rem;margin-bottom:1.5rem;flex-wrap:wrap}.footer-links a{font-size:.9rem;color:#fff9;transition:color .2s}.footer-links a:hover{color:var(--white)}.footer-copy{font-size:.8rem;opacity:.4}.footer-sha{font-size:.7rem;opacity:.3;font-family:monospace}@media (max-width: 768px){.nav-links{display:none}.navbar{justify-content:space-between}.hero{min-height:400px}.features-grid{grid-template-columns:1fr 1fr}}@media (max-width: 480px){.features-grid,.card-grid{grid-template-columns:1fr}.hero-actions{flex-direction:column}}.report-hero{position:relative;min-height:360px;background-size:cover;background-position:center;display:flex;align-items:flex-end;padding-bottom:3rem}.report-hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,#354d2f59,#1e1e1ed1)}.report-hero-content{position:relative;z-index:1;color:var(--white)}.report-hero-content h1{font-size:clamp(1.8rem,4vw,3rem);font-weight:800;line-height:1.15;margin-bottom:.5rem;text-shadow:0 2px 8px rgba(0,0,0,.4)}.back-link{position:absolute;top:1.25rem;left:2rem;z-index:2;color:var(--white);font-size:.88rem;font-weight:600;background:#00000073;padding:.35rem .75rem;border-radius:4px;transition:background .2s}.back-link:hover{background:#000000a6}.report-location{font-size:.95rem;opacity:.82;margin-top:.25rem}.report-body{padding:3rem 2rem 5rem}.report-section{margin-bottom:3rem}.report-section-title{font-size:1.3rem;font-weight:700;color:var(--green-dark);margin-bottom:1.25rem;padding-bottom:.5rem;border-bottom:2px solid var(--cream-dark)}.conditions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.cond-stat{background:var(--white);border-radius:10px;padding:1.25rem 1rem;text-align:center;box-shadow:var(--shadow)}.cond-stat-icon{font-size:1.8rem;margin-bottom:.4rem}.cond-stat-value{font-size:1.15rem;font-weight:700;color:var(--green-dark);margin-bottom:.2rem}.rock-value{font-size:.95rem}.cond-stat-label{font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.timelapse-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.timelapse-header .report-section-title{margin-bottom:0}.timelapse-sync-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.25rem;background:var(--green-dark);color:var(--white);border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .15s}.timelapse-sync-btn:hover{opacity:.85}.timelapse-controls{display:flex;gap:.5rem}.timelapse-speed-label{display:inline-flex;align-items:center;gap:.4rem;font-size:.9rem;font-weight:600;color:var(--text)}.timelapse-speed{padding:.45rem .75rem;border:1px solid var(--border);border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;background:var(--white);color:var(--text)}.timelapse-scrubber{width:100%;margin-bottom:1rem;accent-color:var(--green-dark);cursor:pointer}.timelapse-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.timelapse-item{display:flex;flex-direction:column;gap:.5rem}.timelapse-video{width:100%;max-height:480px;object-fit:contain;border-radius:12px;box-shadow:var(--shadow);background:#000;display:block}.timelapse-label{font-size:.8rem;color:var(--text-muted);text-align:center;margin:0}.forecast-strip{display:grid;grid-template-columns:repeat(7,1fr);gap:.75rem}.forecast-day{background:var(--white);border-radius:10px;padding:1rem .5rem;text-align:center;box-shadow:var(--shadow)}.forecast-label{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.5rem}.forecast-icon{font-size:1.6rem;margin-bottom:.4rem}.forecast-condition{font-size:.72rem;color:var(--text-muted);margin-bottom:.5rem;line-height:1.3}.forecast-temps{display:flex;justify-content:center;gap:.4rem;font-size:.88rem;font-weight:600}.temp-high{color:var(--green-dark)}.temp-low{color:var(--text-muted)}.report-columns{display:grid;grid-template-columns:1fr 320px;gap:2.5rem;align-items:start}.report-main{margin-bottom:0}.reports-list{display:flex;flex-direction:column;gap:1rem}.report-card{background:var(--white);border-radius:10px;padding:1.25rem 1.5rem;box-shadow:var(--shadow)}.report-card-header{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:.75rem}.report-user{font-weight:700;color:var(--green-dark)}.report-date{font-size:.8rem;color:var(--text-muted);margin-left:auto}.report-text{font-size:.92rem;color:var(--text);line-height:1.6}.star-rating{display:flex;gap:1px}.star{font-size:.95rem;color:var(--cream-dark)}.star.filled{color:#e6a817}.report-sidebar .report-section{margin-bottom:0}.sidebar-block{background:var(--white);border-radius:10px;padding:1rem 1.25rem;box-shadow:var(--shadow);margin-bottom:1.25rem}.sidebar-row{display:flex;justify-content:space-between;align-items:baseline;padding:.5rem 0;border-bottom:1px solid var(--cream-dark);font-size:.9rem}.sidebar-row:last-child{border-bottom:none}.sidebar-label{color:var(--text-muted);font-weight:500}.sidebar-value{font-weight:700;color:var(--green-dark);text-align:right}.coords{font-size:.78rem;font-family:monospace}.access-notes{background:#fffbea;border-left:3px solid #e6a817;border-radius:0 8px 8px 0;padding:1rem 1.25rem;margin-bottom:1.25rem}.access-notes h3{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#856404;margin-bottom:.4rem}.access-notes p{font-size:.88rem;color:var(--text);line-height:1.6}.map-btn{display:block;text-align:center}@media (max-width: 960px){.report-columns{grid-template-columns:1fr}.forecast-strip{grid-template-columns:repeat(7,1fr);gap:.4rem}.forecast-day{padding:.75rem .25rem}}@media (max-width: 640px){.forecast-strip{grid-template-columns:repeat(4,1fr)}.forecast-strip .forecast-day:nth-child(n+5){display:none}.conditions-grid{grid-template-columns:repeat(3,1fr)}}.btn-logout{background:none;border:1px solid var(--green);color:var(--green-dark);padding:.4rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;margin-left:auto}.btn-logout:hover{background:var(--green);color:var(--white)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--cream)}.login-form{background:var(--white);border-radius:12px;box-shadow:var(--shadow);padding:2.5rem 2rem;display:flex;flex-direction:column;gap:1rem;width:100%;max-width:340px}.login-form h1{font-size:1.5rem;color:var(--green-dark);text-align:center}.login-form input{padding:.65rem 1rem;border:1px solid var(--cream-dark);border-radius:6px;font-size:1rem;outline:none}.login-form input:focus{border-color:var(--green)}.login-form button{padding:.7rem;background:var(--green);color:var(--white);border:none;border-radius:6px;font-size:1rem;cursor:pointer}.login-form button:hover{background:var(--green-dark)}.login-error{color:#c0392b;font-size:.9rem;text-align:center}
