/* ============================================
   OutboundJournal — Adventurer Theme
   ============================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root {
    --bg:         #F5F2E7;
    --orange:     #b45309;
    --orange-dark: #92400e;
    --green:      #4A5D4E;
    --ink:        #2B2B2B;
    --ink-light:  #5a5a5a;
    --border:     rgba(74,93,78,0.2);
    --header-h:   72px;
    --max-w:      1200px;
}

html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:'Lora',Georgia,serif;font-size:17px;line-height:1.75;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

.mono{font-family:'JetBrains Mono','Courier New',monospace;font-size:.78rem;letter-spacing:.06em}

/* Grain overlay */
.grain-overlay{position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.07'/%3E%3C/svg%3E");background-size:200px;pointer-events:none;z-index:1;mix-blend-mode:multiply;opacity:.55}

/* ============================================ HEADER */
.site-header{position:fixed;top:0;left:0;right:0;height:var(--header-h);background:var(--bg);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 2.5rem;z-index:100;transition:box-shadow .3s}
.site-header.scrolled{box-shadow:0 2px 20px rgba(43,43,43,.08)}

.site-header nav a{font-family:'Montserrat',sans-serif;font-size:.7rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-light);margin:0 1.1rem;transition:color .2s;position:relative}
.site-header nav a::after{content:'';position:absolute;bottom:-3px;left:0;right:0;height:1px;background:var(--orange);transform:scaleX(0);transition:transform .2s}
.site-header nav a:hover,.site-header nav a.active{color:var(--ink)}
.site-header nav a:hover::after,.site-header nav a.active::after{transform:scaleX(1)}

/* Logo */
.logo{display:flex;align-items:center;gap:.7rem;text-decoration:none}
.logo-icon{width:28px;height:28px;color:var(--orange);flex-shrink:0}
.logo-img{height:36px;width:auto;object-fit:contain}
.logo-text{display:flex;flex-direction:column;line-height:1}
.logo-outbound{font-family:'Playfair Display',Georgia,serif;font-weight:900;font-size:1rem;letter-spacing:.2em;color:var(--ink);text-transform:uppercase}
.logo-journal{font-family:'JetBrains Mono',monospace;font-size:.55rem;letter-spacing:.38em;color:var(--ink-light);text-transform:uppercase;margin-top:3px}

/* Mobile toggle */
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.nav-toggle span{display:block;width:22px;height:1.5px;background:var(--ink);transition:transform .3s,opacity .3s}
.nav-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

.mobile-nav{display:none;position:fixed;top:var(--header-h);left:0;right:0;background:var(--bg);border-bottom:1px solid var(--border);flex-direction:column;padding:1.5rem 2rem;gap:1.2rem;z-index:99}
.mobile-nav a{font-family:'Montserrat',sans-serif;font-size:.82rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--ink)}
.mobile-nav.open{display:flex}

/* ============================================ HERO */
.hero{position:relative;margin-top:var(--header-h);height:92vh;min-height:520px;display:flex;align-items:flex-end;filter:saturate(.72) contrast(1.05);overflow:hidden}
.hero-bg-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(43,43,43,.78) 0%,rgba(43,43,43,.1) 55%,transparent 100%);z-index:2}
.hero-content{position:relative;z-index:3;padding:3.5rem 4rem;max-width:720px}
.hero-eyebrow{color:var(--orange);text-transform:uppercase;letter-spacing:.18em;margin-bottom:.8rem}
.hero-headline{font-family:'Playfair Display',Georgia,serif;font-size:clamp(2.4rem,5vw,4rem);font-weight:900;color:#F5F2E7;line-height:1.15;margin-bottom:1.8rem}
.hero-cta{display:inline-block;font-family:'Montserrat',sans-serif;font-size:.75rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:#F5F2E7;border:1px solid rgba(245,242,231,.45);padding:.75rem 1.8rem;transition:background .2s,border-color .2s,color .2s}
.hero-cta:hover{background:var(--orange);border-color:var(--orange);color:#fff}

/* ============================================ MAIN */
.main-content{max-width:var(--max-w);margin:0 auto;padding:4rem 2rem 6rem}

/* ============================================ POST GRID */
.post-grid{columns:2;column-gap:2.5rem}
.post-card{break-inside:avoid;margin-bottom:3.5rem}
.post-card-image-link{display:block}

/* Analog effect: grayscale by default, color on hover */
.post-card-image{position:relative;width:100%;overflow:hidden;filter:grayscale(1) contrast(1.05);transition:filter .5s ease}
.post-card-img{width:100%;height:auto;aspect-ratio:800/520;object-fit:cover;display:block}
.post-card:hover .post-card-image{filter:grayscale(0) saturate(.85) contrast(1.05)}

.post-card-body{padding:1.2rem 0 0}
.post-category{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:.65rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--orange);margin-bottom:.5rem}
.post-title{font-family:'Playfair Display',Georgia,serif;font-size:1.3rem;font-weight:700;line-height:1.3;margin-bottom:.4rem}
.post-title a:hover{color:var(--orange)}
.post-location{display:block;color:var(--green);margin-bottom:.5rem;font-size:.7rem}
.post-excerpt{font-size:.92rem;color:var(--ink-light);line-height:1.7;margin-bottom:1rem}
.post-meta{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--border);padding-top:.75rem}
.post-date{color:var(--ink-light)}
.post-read-more{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--orange);transition:letter-spacing .2s}
.post-read-more:hover{letter-spacing:.18em}

/* ============================================ SINGLE POST */
.single-post{margin-top:var(--header-h)}
.single-hero{position:relative;height:78vh;min-height:440px;display:flex;align-items:flex-end;filter:saturate(.72) contrast(1.05);overflow:hidden}
.single-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(43,43,43,.82) 0%,transparent 65%);z-index:2}
.single-hero-content{position:relative;z-index:3;padding:3rem 4rem;max-width:860px}
.single-hero-content h1{font-family:'Playfair Display',Georgia,serif;font-size:clamp(2rem,4vw,3.2rem);font-weight:900;color:#F5F2E7;line-height:1.2;margin:.5rem 0 1rem}
.single-meta{display:flex;gap:2rem;color:rgba(245,242,231,.65)}
.single-location::before{content:'';margin-right:.4rem}

.single-body-wrap{display:flex;justify-content:center;padding:4rem 2rem 5rem}
.single-body{max-width:740px;width:100%}
.single-excerpt{font-size:1.12rem;font-style:italic;color:var(--ink-light);border-left:3px solid var(--orange);padding-left:1.4rem;margin-bottom:2.5rem;line-height:1.85}

.post-content p{margin-bottom:1.5rem;font-size:1.02rem;line-height:1.88}
.post-content h2,.post-content h3{font-family:'Playfair Display',Georgia,serif;margin:2.5rem 0 1rem}
.post-content h2{font-size:1.6rem}
.post-content h3{font-size:1.25rem}
.post-content blockquote{border-left:3px solid var(--green);padding-left:1.4rem;margin:2rem 0;font-style:italic;color:var(--ink-light)}
.post-content ul,.post-content ol{margin:0 0 1.5rem 1.5rem}
.post-content li{margin-bottom:.4rem}

/* Inline media figures */
.post-figure{margin:2.5rem 0}
.post-figure-img{position:relative;width:100%;padding-top:62%;background-size:cover;background-position:center;filter:saturate(.75) contrast(1.05)}
.post-figure figcaption{margin-top:.6rem;color:var(--ink-light);font-size:.72rem;letter-spacing:.06em}

/* Field notes */
.post-fieldnotes{margin-top:3rem;padding:1.5rem;border:1px solid var(--border);background:rgba(74,93,78,.04)}
.fieldnotes-title{color:var(--green);text-transform:uppercase;letter-spacing:.18em;margin-bottom:1rem}
.fieldnotes-list{display:grid;grid-template-columns:auto 1fr;gap:.4rem 1.5rem;align-items:baseline}
.fieldnotes-list dt{color:var(--ink-light);text-transform:uppercase;letter-spacing:.1em;font-size:.68rem}
.fieldnotes-list dd{font-size:.9rem}
.coords{color:var(--ink-light);margin-left:.5rem;font-size:.7rem}

/* Related */
.related-posts{background:rgba(74,93,78,.05);padding:4rem 2rem;border-top:1px solid var(--border)}
.related-title{text-align:center;color:var(--ink-light);text-transform:uppercase;letter-spacing:.18em;margin-bottom:2.5rem}
.post-grid--related{max-width:900px;margin:0 auto}

/* ============================================ COMMENTS */
.comments-section{padding:4rem 2rem 6rem;border-top:1px solid var(--border)}
.comments-inner{max-width:740px;margin:0 auto}
.comments-title{font-family:'Playfair Display',Georgia,serif;font-size:1.5rem;font-weight:700;margin-bottom:2rem}
.comments-title .mono{color:var(--ink-light);font-size:.85rem}

.comments-list{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:3rem}
.comment{padding:1.2rem 0;border-bottom:1px solid var(--border)}
.comment-meta{display:flex;align-items:baseline;gap:1rem;margin-bottom:.5rem}
.comment-author{font-weight:500;font-size:.95rem}
.comment-date{color:var(--ink-light)}
.comment-body{font-size:.95rem;line-height:1.75;color:var(--ink-light)}

.comment-form-wrap{margin-top:2.5rem}
.comment-form-title{font-family:'Playfair Display',Georgia,serif;font-size:1.1rem;font-weight:700;margin-bottom:1.5rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{margin-bottom:1.2rem}
.form-group label{display:block;font-family:'JetBrains Mono',monospace;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-light);margin-bottom:.4rem}
.form-group input,.form-group textarea{width:100%;font-family:'Lora',Georgia,serif;font-size:.92rem;padding:.65rem .9rem;border:1px solid var(--border);background:#fff;color:var(--ink);outline:none;transition:border-color .2s;line-height:1.5}
.form-group input:focus,.form-group textarea:focus{border-color:var(--orange)}
.form-group textarea{resize:vertical;min-height:120px}
.req{color:var(--orange)}
.req-note{color:var(--ink-light);font-size:.65rem;letter-spacing:.04em;text-transform:none}
.comment-submit{background:var(--orange);color:#fff;font-family:'Montserrat',sans-serif;font-size:.72rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;padding:.8rem 2rem;border:none;cursor:pointer;transition:background .2s}
.comment-submit:hover{background:var(--orange-dark)}

/* ============================================ ARCHIVE HEADER */
.archive-header{margin-bottom:3rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}
.archive-header p.mono{color:var(--orange);text-transform:uppercase;letter-spacing:.18em;margin-bottom:.4rem}
.archive-header h2{font-family:'Playfair Display',Georgia,serif;font-size:2.2rem;font-weight:700}
.clear-filter{display:inline-block;margin-top:.8rem;color:var(--ink-light);font-size:.72rem;letter-spacing:.08em;transition:color .2s}
.clear-filter:hover{color:var(--orange)}

/* ============================================ PAGE */
.page-content{padding-top:calc(var(--header-h) + 4rem)}
.page-body-wrap{display:flex;justify-content:center;padding:0 2rem 6rem}
.page-body{max-width:740px;width:100%}
.page-title{font-family:'Playfair Display',Georgia,serif;font-size:2.4rem;font-weight:900;margin-bottom:2rem;line-height:1.2}

/* ============================================ PAGINATION */
.pagination{display:flex;align-items:center;justify-content:center;gap:2rem;margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border)}
.pagination a{color:var(--orange);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;transition:letter-spacing .2s}
.pagination a:hover{letter-spacing:.18em}
.pagination span{color:var(--ink-light)}
.no-posts{text-align:center;color:var(--ink-light);padding:4rem 0;letter-spacing:.1em}

/* ============================================ ALERTS */
.alert{padding:.8rem 1.2rem;margin-bottom:1.5rem;font-size:.78rem;letter-spacing:.05em;border-left:3px solid}
.alert-success{background:rgba(74,93,78,.08);border-color:var(--green);color:var(--green)}
.alert-error{background:rgba(180,83,9,.07);border-color:var(--orange);color:var(--orange-dark)}

/* ============================================ FOOTER */
.site-footer{background:var(--ink);color:var(--bg);padding:4rem 2rem 0}
.footer-inner{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:1fr 2fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(245,242,231,.1);align-items:start}
.footer-logo{display:flex;align-items:center;gap:.7rem}
.footer-logo .logo-icon{color:var(--orange)}
.footer-logo .logo-outbound{color:var(--bg)}
.footer-logo .logo-journal{color:rgba(245,242,231,.4)}
.expedition-label{color:var(--orange);text-transform:uppercase;letter-spacing:.2em;margin-bottom:.4rem}
.expedition-sub{font-size:.88rem;color:rgba(245,242,231,.55);margin-bottom:1.2rem;line-height:1.6}
.subscribe-form{display:flex}
.subscribe-form input{flex:1;background:rgba(245,242,231,.07);border:1px solid rgba(245,242,231,.18);border-right:none;color:var(--bg);font-family:'JetBrains Mono',monospace;font-size:.8rem;padding:.7rem 1rem;outline:none;transition:border-color .2s}
.subscribe-form input::placeholder{color:rgba(245,242,231,.3)}
.subscribe-form input:focus{border-color:var(--orange)}
.subscribe-form button{background:var(--orange);border:1px solid var(--orange);color:#fff;font-family:'Montserrat',sans-serif;font-size:.68rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;padding:.7rem 1.2rem;cursor:pointer;transition:background .2s}
.subscribe-form button:hover{background:var(--orange-dark)}
.bmc-btn{display:inline-flex;align-items:center;gap:0.5rem;background:var(--orange);border:1px solid var(--orange);color:#fff;font-family:'Montserrat',sans-serif;font-size:.68rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;padding:.7rem 1.2rem;cursor:pointer;transition:background .2s;text-decoration:none}
.bmc-btn:hover{background:var(--orange-dark)}
.subscribe-msg{margin-top:.6rem;color:var(--orange);min-height:1.2em}
.footer-nav{display:flex;flex-direction:column;gap:.8rem;align-items:flex-end}
.footer-nav a{font-family:'Montserrat',sans-serif;font-size:.7rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:rgba(245,242,231,.5);transition:color .2s}
.footer-nav a:hover{color:var(--orange)}
.footer-bottom{max-width:var(--max-w);margin:0 auto;padding:1.2rem 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.8rem;color:rgba(245,242,231,.25);font-size:.7rem;letter-spacing:.06em}
.footer-legal{display:flex;gap:1.2rem}
.footer-legal a{color:rgba(245,242,231,.3);text-decoration:none;transition:color .2s}
.footer-legal a:hover{color:var(--orange)}

/* ============================================ GDPR MODAL */
/* Buttons */
.gdpr-btn{font-family:'Montserrat',sans-serif;font-size:.68rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;padding:.55rem 1rem;border:none;cursor:pointer;transition:background .2s;white-space:nowrap}
.gdpr-btn--accept{background:var(--orange);color:#fff}
.gdpr-btn--accept:hover{background:var(--orange-dark)}
.gdpr-btn--reject{background:rgba(43,43,43,.08);color:var(--ink-light);border:1px solid var(--border)}
.gdpr-btn--reject:hover{background:rgba(43,43,43,.14)}
.gdpr-btn--manage{background:transparent;color:var(--ink-light);border:1px solid var(--border)}
.gdpr-btn--manage:hover{color:var(--ink);border-color:var(--ink-light)}
.gdpr-btn--save{background:var(--green);color:#fff}
.gdpr-btn--save:hover{background:#3a4d3e}

/* Manage floating button */
.gdpr-manage-btn{position:fixed;bottom:1.2rem;left:1.2rem;width:38px;height:38px;border-radius:50%;background:var(--ink);color:var(--bg);border:none;cursor:pointer;font-size:1rem;z-index:9997;box-shadow:0 2px 12px rgba(43,43,43,.3);transition:transform .2s,box-shadow .2s;display:flex;align-items:center;justify-content:center}
.gdpr-manage-btn:hover{transform:scale(1.1);box-shadow:0 4px 18px rgba(43,43,43,.4)}

/* Modal overlay */
.gdpr-overlay{position:fixed;inset:0;background:rgba(43,43,43,.72);z-index:9999;display:flex;align-items:center;justify-content:center;padding:1rem;backdrop-filter:blur(3px)}
.gdpr-modal{background:var(--bg);max-width:520px;width:100%;padding:2.2rem 2rem 1.6rem;border-top:3px solid var(--orange);box-shadow:0 20px 60px rgba(43,43,43,.35);max-height:90vh;overflow-y:auto}
.gdpr-modal-header{display:flex;align-items:center;gap:.8rem;margin-bottom:1rem}
.gdpr-modal-icon{font-size:1.4rem}
.gdpr-modal-title{font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink)}
.gdpr-modal-text{font-size:.85rem;color:var(--ink-light);line-height:1.65;margin-bottom:1.5rem}

.gdpr-toggles{display:flex;flex-direction:column;border:1px solid var(--border);margin-bottom:1.5rem}
.gdpr-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.9rem 1rem;border-bottom:1px solid var(--border)}
.gdpr-toggle-row:last-child{border-bottom:none}
.gdpr-toggle-info{display:flex;flex-direction:column;gap:.2rem;flex:1}
.gdpr-toggle-label{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink)}
.gdpr-toggle-desc{font-size:.78rem;color:var(--ink-light);line-height:1.5;font-family:'Lora',Georgia,serif}
.gdpr-badge{font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--green);border:1px solid var(--green);padding:.2rem .5rem;white-space:nowrap}

.gdpr-switch{position:relative;display:inline-block;width:40px;height:22px;flex-shrink:0}
.gdpr-switch input{opacity:0;width:0;height:0}
.gdpr-slider{position:absolute;inset:0;background:rgba(43,43,43,.2);cursor:pointer;transition:.3s;border-radius:22px}
.gdpr-slider::before{content:'';position:absolute;height:16px;width:16px;left:3px;bottom:3px;background:#fff;transition:.3s;border-radius:50%}
.gdpr-switch input:checked + .gdpr-slider{background:var(--orange)}
.gdpr-switch input:checked + .gdpr-slider::before{transform:translateX(18px)}

.gdpr-modal-actions{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:1rem}
.gdpr-modal-actions .gdpr-btn{flex:1;min-width:90px;padding:.65rem .8rem}
.gdpr-links{font-size:.65rem;letter-spacing:.06em;color:var(--ink-light);text-align:center}
.gdpr-links a{color:var(--ink-light);text-decoration:underline;text-underline-offset:2px}
.gdpr-links a:hover{color:var(--orange)}

/* ============================================ VIDEO PLAYER */
.post-video-section{background:var(--ink);padding:4rem 2rem;border-top:1px solid rgba(245,242,231,.08)}
.post-video-inner{max-width:860px;margin:0 auto}
.post-video-title{color:var(--orange);text-transform:uppercase;letter-spacing:.18em;margin-bottom:1.5rem}
.video-embed-wrap{position:relative;width:100%;padding-top:56.25%;background:#000;overflow:hidden}
.video-embed-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:none}
.video-direct{position:absolute;inset:0;width:100%;height:100%}
.video-poster{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:rgba(43,43,43,.55);cursor:pointer;transition:background .3s}
.video-poster:hover{background:rgba(43,43,43,.35)}
.video-play-btn{background:none;border:none;cursor:pointer;color:#F5F2E7;width:72px;height:72px;transition:transform .2s,color .2s}
.video-play-btn:hover{transform:scale(1.1);color:var(--orange)}
.video-play-btn svg{width:100%;height:100%}
.video-play-label{font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(245,242,231,.6)}

/* ============================================ CONTACT PAGE */
.contact-page{padding-top:calc(var(--header-h) + 4rem)}
.contact-wrap{display:flex;justify-content:center;padding:0 2rem 6rem}
.contact-inner{max-width:680px;width:100%}
.contact-title{font-family:'Playfair Display',Georgia,serif;font-size:2.4rem;font-weight:900;margin-bottom:.6rem;line-height:1.2}
.contact-subtitle{color:var(--ink-light);margin-bottom:2.5rem;font-size:.95rem}
.contact-form .form-group label{display:block;font-family:'JetBrains Mono',monospace;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-light);margin-bottom:.4rem}
.contact-form .form-group input,.contact-form .form-group textarea,.contact-form .form-group select{width:100%;font-family:'Lora',Georgia,serif;font-size:.92rem;padding:.65rem .9rem;border:1px solid var(--border);background:#fff;color:var(--ink);outline:none;transition:border-color .2s}
.contact-form .form-group input:focus,.contact-form .form-group textarea:focus{border-color:var(--orange)}
.contact-form .form-group textarea{resize:vertical;min-height:140px}
.contact-tnc{display:flex;align-items:flex-start;gap:.6rem;margin-bottom:1.5rem;font-size:.85rem;color:var(--ink-light);line-height:1.6}
.contact-tnc input[type=checkbox]{margin-top:.2rem;flex-shrink:0;accent-color:var(--orange)}
.contact-tnc a{color:var(--orange)}
.contact-submit{background:var(--orange);color:#fff;font-family:'Montserrat',sans-serif;font-size:.72rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;padding:.85rem 2.2rem;border:none;cursor:pointer;transition:background .2s}
.contact-submit:hover{background:var(--orange-dark)}

/* ============================================ RESPONSIVE */
@media(max-width:900px){
    .post-grid{columns:1}
    .footer-inner{grid-template-columns:1fr;gap:2rem}
    .footer-nav{align-items:flex-start}
    .form-row{grid-template-columns:1fr}
}
@media(max-width:768px){
    .nav-left,.nav-right{display:none}
    .nav-toggle{display:flex}
    .site-header{padding:0 1.5rem}
    .hero-content{padding:2rem 1.5rem}
    .single-hero-content{padding:2rem 1.5rem}
    .single-meta{flex-direction:column;gap:.4rem}
    .main-content{padding:2.5rem 1.2rem 4rem}
    .gdpr-inner{flex-direction:column;gap:1rem}
}

/* ============================================ HOME 3-COLUMN LAYOUT */
.home-columns{display:grid;grid-template-columns:1fr 1fr 320px;gap:2.5rem;align-items:start}
.home-posts-col{grid-column:1/3}
.home-posts-col .post-grid{columns:2;column-gap:2rem}
.trail-updates-col{grid-column:3/4}

/* ============================================ TRAIL UPDATES */
.trail-updates-col{position:sticky;top:calc(var(--header-h) + 2rem);max-height:calc(100vh - var(--header-h) - 4rem);overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.trail-updates-col::-webkit-scrollbar{width:4px}
.trail-updates-col::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}

.trail-updates-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:1rem;margin-bottom:1.2rem;border-bottom:2px solid var(--orange)}
.trail-updates-label{color:var(--orange);text-transform:uppercase;letter-spacing:.18em}
.trail-updates-empty{color:var(--ink-light);padding:1rem 0}

.trail-updates-list{display:flex;flex-direction:column;gap:0}

.trail-update{padding:1.2rem 0;border-bottom:1px solid var(--border)}
.trail-update:last-child{border-bottom:none}

.tu-meta{display:flex;align-items:center;gap:.8rem;margin-bottom:.6rem;flex-wrap:wrap}
.tu-date{color:var(--orange);font-size:.68rem;letter-spacing:.08em}
.tu-location{color:var(--green);font-size:.68rem;letter-spacing:.06em}
.tu-location::before{content:'📍';margin-right:.2rem;font-size:.7rem}

.tu-body{font-size:.9rem;line-height:1.7;color:var(--ink);margin-bottom:.8rem}

.tu-image-wrap{margin:.8rem 0;border-radius:2px;overflow:hidden}
.tu-image{width:100%;max-height:260px;object-fit:cover;filter:saturate(.8) contrast(1.05);transition:filter .4s}
.trail-update:hover .tu-image{filter:saturate(1) contrast(1)}

.tu-video-wrap{position:relative;width:100%;padding-top:56.25%;margin:.8rem 0;background:#000;overflow:hidden}
.tu-video-wrap iframe,.tu-video-wrap video{position:absolute;inset:0;width:100%;height:100%;border:none}

/* Comments */
.tu-comments{margin-top:.8rem}
.tu-comments-list{display:flex;flex-direction:column;gap:.6rem;margin-bottom:.6rem}
.tu-comment{padding:.5rem 0;border-top:1px solid var(--border)}
.tu-comment-author{font-size:.8rem;font-weight:600;color:var(--ink);margin-right:.5rem}
.tu-comment-date{font-size:.65rem;color:var(--ink-light);letter-spacing:.06em}
.tu-comment-body{font-size:.82rem;color:var(--ink-light);line-height:1.6;margin-top:.2rem}
.tu-comment-flash{color:var(--green);font-size:.72rem;letter-spacing:.06em;margin:.4rem 0}

.tu-comment-toggle{margin-top:.4rem}
.tu-comment-toggle summary{font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-light);cursor:pointer;list-style:none;transition:color .2s;user-select:none}
.tu-comment-toggle summary::-webkit-details-marker{display:none}
.tu-comment-toggle summary:hover{color:var(--orange)}
.tu-comment-toggle[open] summary{color:var(--orange)}

.tu-comment-form{margin-top:.8rem;display:flex;flex-direction:column;gap:.5rem}
.tu-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.tu-comment-form input,.tu-comment-form textarea{font-family:'Lora',Georgia,serif;font-size:.82rem;padding:.5rem .7rem;border:1px solid var(--border);background:#fff;color:var(--ink);outline:none;transition:border-color .2s;width:100%}
.tu-comment-form input:focus,.tu-comment-form textarea:focus{border-color:var(--orange)}
.tu-comment-form textarea{resize:vertical;min-height:70px}
.tu-submit{align-self:flex-start;background:var(--orange);color:#fff;border:none;padding:.45rem 1.1rem;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:background .2s}
.tu-submit:hover{background:var(--orange-dark)}

/* ============================================ RESPONSIVE — trail updates */
@media(max-width:1100px){
    .home-columns{grid-template-columns:1fr 280px;gap:2rem}
    .home-posts-col{grid-column:1/2}
    .home-posts-col .post-grid{columns:1}
    .trail-updates-col{grid-column:2/3}
}
@media(max-width:800px){
    .home-columns{grid-template-columns:1fr}
    .home-posts-col{grid-column:1/-1}
    .trail-updates-col{grid-column:1/-1;position:static;max-height:none;overflow-y:visible;border-top:2px solid var(--border);padding-top:2rem}
    .trail-updates-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:0 2rem}
    .trail-update{border-bottom:1px solid var(--border)}
}
@media(max-width:500px){
    .trail-updates-list{grid-template-columns:1fr}
    .tu-form-row{grid-template-columns:1fr}
}

/* ============================================ FOOTER SOCIAL */
.footer-social{display:flex;gap:.8rem;margin-top:1rem;justify-content:flex-end}
.footer-social-link{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid rgba(245,242,231,.18);color:rgba(245,242,231,.45);transition:color .2s,border-color .2s}
.footer-social-link:hover{color:var(--orange);border-color:var(--orange)}
.footer-social-link svg{width:16px;height:16px}
