/*
Theme Name: FONH Journey v6q
Theme URI: https://fonh.com
Author: Chris & Cathy
Description: From Buenos Aires to Italy — Our 40th Anniversary travel journal
Version: 6.16
License: GNU General Public License v2 or later
Text Domain: fonh-journey
*/
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;1,400;1,600&family=Lora:ital,wght@0,400;0,500;1,400&family=Raleway:wght@300;400;500;600&display=swap');

:root {
  --accent:#185FA5; --accent-dark:#0C447C; --accent-deeper:#042C53;
  --accent-light:#85B7EB; --accent-pale:#B5D4F4; --accent-ghost:#E6F1FB;
  --title-bar:#3A7FC1; --title-bar-dk:#2E6DA4;
  --paper:#F8FAFD; --white:#FFFFFF; --ink:#0D1F35; --ink-soft:#2C4A6E; --ink-muted:#5A7A9E;
  --border:#C2D8F0; --border-soft:#DDE9F7; --cathy-bg:#E1F5EE; --cathy-color:#085041;
  --font-display:'Playfair Display',Georgia,serif; --font-body:-apple-system,BlinkMacSystemFont,'Segoe UI','Helvetica Neue',Arial,sans-serif;
  --font-ui:'Raleway',sans-serif; --max-width:1200px; --radius:6px; --post-font-size:18px;
  --post-line-height:1.6; --page-margin:90px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;margin-top:0!important;}
body{font-family:var(--font-body);background:var(--paper);color:var(--ink);line-height:1.8;overflow-x:hidden;}
a{color:var(--accent);text-decoration:none;transition:color .2s;}
a:hover{color:var(--accent-dark);}
img{max-width:100%;height:auto;display:block;}
#wpadminbar{display:none!important;}

/* ── Name prompt ─────────────────────────────────────────── */
#name-overlay-blur{display:none;position:fixed;inset:0;backdrop-filter:blur(5px);background:rgba(4,44,83,.48);z-index:8999;}
#name-overlay{display:none;position:fixed;inset:0;z-index:9000;align-items:center;justify-content:center;padding:1rem;}
#name-overlay.active{display:flex;}
#name-overlay.active+#name-overlay-blur{display:flex;}
.name-prompt-box{background:var(--white);border-radius:12px;padding:2.25rem 2rem;max-width:390px;width:100%;text-align:center;border:1px solid var(--border);}
.name-prompt-icon{font-size:1.8rem;color:var(--accent);margin-bottom:.6rem;}
.name-prompt-box h2{font-family:var(--font-display);font-size:1.35rem;font-style:italic;color:var(--accent-deeper);margin-bottom:.35rem;}
.name-prompt-box p{font-family:var(--font-ui);font-size:.8rem;color:var(--ink-muted);margin-bottom:1.1rem;line-height:1.6;font-weight:300;}
.name-prompt-box input{width:100%;padding:.6rem 1rem;border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-ui);font-size:1rem;background:var(--accent-ghost);color:var(--ink);margin-bottom:.45rem;outline:none;text-align:center;transition:border-color .2s;}
.name-prompt-box input:focus{border-color:var(--accent);}
.name-prompt-error{font-family:var(--font-ui);font-size:.75rem;color:#993C1D;margin-bottom:.4rem;display:none;}
.btn-primary{width:100%;padding:.65rem;background:var(--accent);color:var(--white);border:none;border-radius:var(--radius);font-family:var(--font-ui);font-size:.88rem;font-weight:500;cursor:pointer;letter-spacing:.05em;transition:background .2s;}
.btn-primary:hover{background:var(--accent-dark);}

/* ── Header / banner ─────────────────────────────────────── */
.site-header{position:fixed;top:0;left:0;right:0;z-index:500;}
.banner-wrap{position:relative;width:100%;height:200px;background:var(--accent-deeper);overflow:hidden;}
.banner-wrap img.banner-img{width:100%;height:100%;object-fit:cover;object-position:center;opacity:.68;}
.banner-placeholder{width:100%;height:100%;background:var(--accent-deeper);display:flex;align-items:center;justify-content:center;}
.banner-placeholder span{font-family:var(--font-ui);font-size:.7rem;color:var(--accent-pale);letter-spacing:.12em;opacity:.7;text-align:center;padding:0 2rem;}
.banner-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(4,44,83,.1) 0%,rgba(4,44,83,.55) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.75rem 2rem;text-align:center;}
.banner-visitor-name{position:absolute;top:8px;left:12px;font-family:var(--font-ui);font-size:.72rem;color:var(--accent-pale);font-weight:300;letter-spacing:.05em;}
.banner-version{position:absolute;top:8px;right:12px;font-family:var(--font-ui);font-size:.65rem;color:var(--accent-pale);font-weight:300;letter-spacing:.06em;opacity:.6;}
.banner-eyebrow{font-family:var(--font-ui);font-size:.62rem;letter-spacing:.22em;color:var(--accent-pale);text-transform:uppercase;margin-bottom:.35rem;}
.banner-title{font-family:var(--font-display);font-size:clamp(1.4rem,5vw,3.8rem);color:var(--white);font-style:italic;line-height:1.15;max-width:800px;}
.banner-subtitle{font-family:var(--font-ui);font-size:.72rem;color:var(--accent-pale);margin-top:.3rem;font-weight:300;letter-spacing:.09em;}
.banner-divider{width:40px;height:1px;background:var(--accent-light);margin:.4rem auto 0;}

/* ── Nav ─────────────────────────────────────────────────── */
.site-nav{background:var(--accent-dark);border-bottom:4px solid var(--accent-ghost);}
.nav-inner{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;height:24px;}
.nav-links{display:flex;gap:1.5rem;list-style:none;}
.nav-links a{font-family:var(--font-ui);font-size:.62rem;font-weight:500;color:var(--accent-pale);letter-spacing:.1em;text-transform:uppercase;transition:color .2s;}
.nav-links a:hover,.nav-links a.current-menu-item{color:var(--white);}
.nav-about-toggle{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;padding:0 8px;height:100%;}
.nav-triangle{width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:6px solid var(--accent-pale);display:block;transition:transform .25s ease;}
.nav-about-toggle.collapsed .nav-triangle{transform:rotate(180deg);}
.nav-about-toggle:hover .nav-triangle{border-bottom-color:var(--white);}
.nav-right{display:flex;align-items:center;gap:1rem;justify-content:flex-end;}
.nav-admin-link{font-family:var(--font-ui);font-size:.6rem;color:var(--accent-light);font-weight:500;}

/* hamburger — right side only, hidden by default on desktop */
.nav-hamburger{display:none;flex-direction:column;gap:4px;cursor:pointer;background:none;border:none;padding:2px;}
.nav-hamburger span{display:block;width:16px;height:1px;background:var(--accent-pale);}

/* ── Fixed secondary wrapper ─────────────────────────────── */
.fixed-secondary{position:fixed;left:0;right:0;z-index:490;}

/* About strip */
.about-strip{background:var(--accent-ghost);overflow:hidden;transition:max-height .3s ease;max-height:80px;}
.about-strip.collapsed{max-height:0;}
.about-strip-inner{max-width:var(--max-width);margin:0 auto;padding:.5rem 1.5rem;}
.about-strip p{font-family:var(--font-ui);font-size:.92rem;font-style:italic;color:var(--ink-soft);line-height:1.5;font-weight:400;}

/* ── Post header bar — single row (desktop) ──────────────── */
.post-header-bar{
  background:var(--title-bar);
  border-bottom:1px solid var(--title-bar-dk);
  display:flex;align-items:stretch;
  height:42px;
  position:relative;
}
.post-header-left{display:flex;align-items:center;gap:.65rem;flex:1;min-width:0;padding:0 1rem 0 1.5rem;}
.post-header-title{font-family:var(--font-display);font-size:1rem;font-style:italic;color:var(--white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.author-badge{font-family:var(--font-ui);font-size:.62rem;font-weight:600;padding:2px 9px;border-radius:20px;letter-spacing:.05em;flex-shrink:0;}
.author-chris{background:rgba(255,255,255,.22);color:var(--white);}
.author-cathy{background:var(--cathy-bg);color:var(--cathy-color);}
.post-date-tag{font-family:var(--font-ui);font-size:.65rem;color:rgba(255,255,255,.78);flex-shrink:0;}
.post-header-right{display:flex;align-items:stretch;flex-shrink:0;height:100%;}
.font-size-controls{display:flex;align-items:center;gap:5px;padding:0 .75rem;border-left:1px solid rgba(255,255,255,.15);height:100%;}
.font-btn{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.28);border-radius:4px;width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-family:var(--font-ui);font-weight:700;color:var(--white);font-size:.8rem;transition:background .15s;}
.font-btn:hover{background:rgba(255,255,255,.3);}
.font-size-label{font-family:var(--font-ui);font-size:.62rem;color:rgba(255,255,255,.75);min-width:24px;text-align:center;letter-spacing:.02em;}
.lh-controls{display:flex;align-items:center;gap:5px;padding:0 .75rem;border-left:1px solid rgba(255,255,255,.15);height:100%;}
.lh-label{font-family:var(--font-ui);font-size:.62rem;color:rgba(255,255,255,.75);min-width:28px;text-align:center;letter-spacing:.02em;}
.comment-trigger-btn{background:var(--accent-dark);color:var(--white);border:none;padding:0 1.1rem;height:100%;font-family:var(--font-ui);font-size:.75rem;font-weight:500;cursor:pointer;letter-spacing:.04em;transition:background .2s;white-space:nowrap;border-left:1px solid rgba(255,255,255,.15);}
.comment-trigger-btn:hover{background:var(--accent-deeper);}

/* Show Entries button — replaces the old floating tab */
.entries-toggle-btn{
  display:flex;align-items:center;gap:5px;
  background:var(--accent-dark);color:var(--white);
  border:none;border-left:1px solid rgba(255,255,255,.15);
  padding:0 1rem;height:100%;
  font-family:var(--font-ui);font-size:.75rem;font-weight:500;
  cursor:pointer;letter-spacing:.04em;white-space:nowrap;
  transition:background .2s;
}
.entries-toggle-btn:hover{background:var(--accent-deeper);}
/* Chevron: ∨ rotates 180° to become ∧ when open */
.entries-chevron{
  font-size:.85rem;line-height:1;
  display:inline-block;
  transition:transform .25s ease;
  transform:rotate(0deg);
}
.entries-chevron.open{transform:rotate(180deg);}

/* ── Entries modal (mobile) ──────────────────────────────── */
.entries-modal-box{
  background:var(--white);
  border-radius:10px;
  width:calc(100% - 2rem);
  max-width:420px;
  max-height:72vh;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  box-shadow:0 8px 32px rgba(4,44,83,.22);
}
.entries-modal-header{
  background:#00897B;
  color:var(--white);
  display:flex;
  align-items:center;
  gap:.5rem;
  padding:.6rem .85rem;
  flex-shrink:0;
}
.entries-modal-title{
  font-family:var(--font-ui);
  font-size:.65rem;font-weight:600;
  letter-spacing:.15em;text-transform:uppercase;
  flex:1;
}
.entries-modal-sort-btn{
  background:rgba(255,255,255,.2);
  border:1px solid rgba(255,255,255,.4);
  border-radius:4px;
  color:var(--white);
  font-family:var(--font-ui);font-size:.62rem;font-weight:500;
  letter-spacing:.03em;text-transform:none;
  padding:2px 7px;cursor:pointer;white-space:nowrap;
  transition:background .15s;
}
.entries-modal-sort-btn:hover{background:rgba(255,255,255,.35);}
.entries-modal-close{
  background:none;border:none;
  color:var(--white);font-size:1.4rem;line-height:1;
  cursor:pointer;padding:0 2px;
  opacity:.8;transition:opacity .15s;
}
.entries-modal-close:hover{opacity:1;}
.entries-modal-list{
  overflow-y:auto;
  flex:1;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
  touch-action:pan-y;
}
.entries-modal-empty{
  padding:2rem 1.5rem;
  font-family:var(--font-ui);font-size:.82rem;
  color:var(--ink-muted);font-style:italic;
  text-align:center;
}

/* ── Sidebar (desktop only — shown alongside post) ───────── */
.sidebar{background:var(--paper);overflow-y:auto;position:relative;transition:width .3s ease,opacity .3s ease;border-left:1px solid var(--border-soft);}
.sidebar::-webkit-scrollbar{width:3px;}
.sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}
.sidebar.collapsed{width:0!important;min-width:0!important;max-width:0!important;overflow:hidden!important;border-left:none!important;opacity:0!important;padding:0!important;}
.sidebar-panel-heading{background:#00897B;color:var(--white);font-family:var(--font-ui);font-size:.64rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;padding:.5rem .75rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:5;}
.sidebar-sort-btn{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.35);border-radius:4px;color:var(--white);font-family:var(--font-ui);font-size:.58rem;font-weight:500;letter-spacing:.04em;text-transform:none;padding:2px 6px;cursor:pointer;white-space:nowrap;transition:background .15s;}
.sidebar-sort-btn:hover{background:rgba(255,255,255,.3);}
.older-post-item{padding:.65rem 1rem;border-bottom:1px solid var(--border-soft);cursor:pointer;transition:background .15s;}
.older-post-item:last-child{border-bottom:none;}
.older-post-item:hover{background:var(--accent-ghost);}
.older-post-item.active{background:var(--accent-ghost);border-left:3px solid var(--accent);}
.older-post-title{font-family:var(--font-display);font-size:.95rem;font-style:italic;color:var(--accent-deeper);line-height:1.3;margin-bottom:2px;}
.older-post-date{font-family:var(--font-ui);font-size:.76rem;color:var(--ink-muted);margin-bottom:3px;}
.older-post-excerpt{font-size:.85rem;color:var(--ink-muted);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.sidebar-home-item{padding:.55rem 1rem;border-bottom:2px solid var(--border);background:var(--accent-ghost);cursor:pointer;font-family:var(--font-ui);font-size:.72rem;color:var(--accent);font-weight:500;transition:background .15s;}
.sidebar-home-item:hover{background:var(--accent-pale);}

/* ── Layout ──────────────────────────────────────────────── */
.site-main{margin:0 var(--page-margin);display:grid;grid-template-columns:1fr;align-items:start;transition:grid-template-columns .3s ease;}
.site-main.sidebar-visible{grid-template-columns:3fr 1fr!important;margin-right:0;}
.site-main.sidebar-hidden{grid-template-columns:1fr!important;}

/* ── Post body ───────────────────────────────────────────── */
.post-area{background:var(--white);overflow-y:auto;}
.post-content-wrap{padding:1.5rem 1.75rem;max-width:720px;margin:0 auto;}
.post-body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Helvetica Neue',Arial,sans-serif!important;font-size:var(--post-font-size)!important;line-height:var(--post-line-height);color:var(--ink-soft);font-style:normal!important;}
.post-body p,.post-body li,.post-body div,.post-body span{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Helvetica Neue',Arial,sans-serif!important;font-size:var(--post-font-size)!important;font-style:normal!important;}
.post-body p{margin-bottom:1rem;}
.post-body p:last-child{margin-bottom:0;}
.post-body img{border-radius:var(--radius);margin:.5rem 0;}

/* ── Image default: full width, no wrap ──────────────────────
   Any image not explicitly floated sits as a full-width block
   with breathing room above and below, like the Venice example.
   ──────────────────────────────────────────────────────────── */
.post-body img,
.post-body figure,
.post-body .wp-block-image{
  display:block;
  width:100%!important;
  max-width:100%!important;
  height:auto!important;
  margin:1.25rem auto;
  border-radius:var(--radius);
}
.post-body figure img,
.post-body .wp-block-image img{
  width:100%;
  height:auto;
  border-radius:var(--radius);
}

/* ── Opt-in text wrapping — set Align Left or Align Right ────
   These override the full-width default when you explicitly
   choose an alignment in the WordPress editor.
   ──────────────────────────────────────────────────────────── */
.post-body .alignleft,
.post-body figure.alignleft,
.post-body .wp-block-image.alignleft{
  float:left;
  width:auto;
  max-width:45%;
  margin:.25rem 1.5rem 1rem 0;
  clear:left;
}
.post-body .alignright,
.post-body figure.alignright,
.post-body .wp-block-image.alignright{
  float:right;
  width:auto;
  max-width:45%;
  margin:.25rem 0 1rem 1.5rem;
  clear:right;
}
/* Explicit centre — full width but centred (same as default, kept for clarity) */
.post-body .aligncenter,
.post-body figure.aligncenter,
.post-body .wp-block-image.aligncenter{
  float:none;
  clear:both;
  margin:1.25rem auto;
  max-width:100%;
}
/* Make sure img inside floated figure also respects border-radius */
.post-body figure.alignleft img,
.post-body figure.alignright img,
.post-body .wp-block-image.alignleft img,
.post-body .wp-block-image.alignright img{
  border-radius:var(--radius);
  width:100%;
  height:auto;
}
/* Gutenberg wide/full alignments */
.post-body .wp-block-image.alignwide,
.post-body .wp-block-image.alignfull{
  float:none;clear:both;
  max-width:100%;margin:1.25rem 0;
}
/* Clearfix */
.post-body::after{content:'';display:table;clear:both;}
.post-body video,.post-body iframe{width:100%;border-radius:var(--radius);margin:1rem 0;}
.post-body figure{margin:1rem 0;}
.post-body figcaption{font-family:var(--font-ui);font-size:.7rem;color:var(--ink-muted);text-align:center;margin-top:.3rem;font-style:italic;}
/* Captions hidden in post body — they show only in the Gallery */
.post-body figcaption{display:none;}
.post-loading{padding:3rem;text-align:center;font-family:var(--font-ui);font-size:.85rem;color:var(--ink-muted);font-style:italic;}

/* ── Comments ────────────────────────────────────────────── */
.post-comments-section{border-top:1px solid var(--border-soft);padding:1.25rem 1.75rem;background:var(--accent-ghost);max-width:720px;margin:0 auto;}
.comments-heading{font-family:var(--font-display);font-size:.92rem;font-style:italic;color:var(--accent-deeper);margin-bottom:.65rem;}
.comment-item{display:flex;gap:.65rem;padding:.6rem .35rem;border-bottom:1px solid var(--border-soft);cursor:pointer;border-radius:4px;transition:background .15s;}
.comment-item:last-of-type{border-bottom:none;}
.comment-item:hover{background:var(--accent-pale);}
.comment-avatar{width:30px;height:30px;border-radius:50%;background:var(--accent-pale);display:flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-size:.7rem;font-weight:600;color:var(--accent-dark);flex-shrink:0;}
.comment-author-name{font-family:var(--font-ui);font-size:.72rem;font-weight:600;color:var(--accent-dark);}
.comment-date-small{font-family:var(--font-ui);font-size:.64rem;color:var(--ink-muted);margin-left:6px;}
.comment-preview{font-size:.78rem;color:var(--ink-soft);line-height:1.5;margin-top:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.comment-read-more{font-family:var(--font-ui);font-size:.64rem;color:var(--accent);margin-top:2px;}

/* ── Gallery ─────────────────────────────────────────────── */
.gallery-page-wrap{padding:2rem 1.75rem;}
.gallery-page-header{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.25rem;}
.gallery-page-title{font-family:var(--font-display);font-size:1.6rem;font-style:italic;color:var(--accent-deeper);margin-bottom:.25rem;}
.gallery-page-sub{font-family:var(--font-ui);font-size:.8rem;color:var(--ink-muted);}

/* Controls row (sort + size) */
.gallery-controls{display:flex;align-items:center;flex-wrap:wrap;gap:1rem;padding-top:.25rem;}
.gallery-sort-wrap,.gallery-size-wrap{display:flex;align-items:center;gap:.5rem;}
.gallery-ctrl-label{font-family:var(--font-ui);font-size:.72rem;color:var(--ink-muted);white-space:nowrap;}
.gallery-sort-select{font-family:var(--font-ui);font-size:.75rem;color:var(--ink);border:1px solid var(--border);border-radius:var(--radius);padding:.25rem .5rem;background:var(--white);cursor:pointer;}
.gallery-sort-select:focus{outline:none;border-color:var(--accent);}
.gallery-size-slider{width:110px;accent-color:var(--accent);cursor:pointer;}

/* Grid — column size driven by CSS variable set by JS */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(var(--gallery-col,200px),1fr));
  gap:1rem;
}
.gallery-item{background:var(--white);border:1px solid var(--border-soft);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:border-color .2s,transform .15s;}
.gallery-item:hover{border-color:var(--accent);transform:translateY(-2px);}
.gallery-item img{width:100%;height:var(--gallery-img-h,160px);object-fit:cover;display:block;transition:height .2s;}
.gallery-item-info{padding:.55rem .75rem;}
.gallery-img-title{font-family:var(--font-body);font-size:.8rem;font-weight:500;color:var(--ink-soft);line-height:1.35;margin-bottom:3px;}
.gallery-blog-label{font-family:var(--font-ui);font-size:.67rem;color:var(--accent);font-weight:500;}
.gallery-blog-label a{color:var(--accent);text-decoration:none;}
.gallery-blog-label a:hover{text-decoration:underline;}
.gallery-caption-inline{color:var(--ink-muted);font-weight:400;}
.gallery-caption{font-family:var(--font-body);font-size:.78rem;color:var(--ink-soft);line-height:1.4;margin-bottom:3px;font-style:italic;}
.gallery-post-title{font-family:var(--font-ui);font-size:.68rem;color:var(--accent);font-weight:500;}
.gallery-post-date{font-family:var(--font-ui);font-size:.63rem;color:var(--ink-muted);}
.gallery-empty{font-family:var(--font-ui);font-size:.9rem;color:var(--ink-muted);font-style:italic;padding:2rem 0;}

/* ── Lightbox ────────────────────────────────────────────── */
.lightbox-backdrop{display:none;position:fixed;inset:0;background:rgba(4,44,83,.92);z-index:3000;align-items:center;justify-content:center;gap:0;padding:0;}
.lightbox-backdrop.open{display:flex;}
.lightbox-center{display:flex;flex-direction:column;align-items:center;max-width:calc(100vw - 140px);max-height:100vh;padding:1rem 0;}
.lightbox-img{max-width:100%;max-height:82vh;object-fit:contain;border-radius:var(--radius);display:block;}
.lightbox-caption{font-family:var(--font-ui);font-size:.8rem;color:var(--accent-pale);text-align:center;margin-top:.75rem;}
.lightbox-close{position:absolute;top:1rem;right:1.25rem;background:none;border:none;color:var(--white);font-size:1.8rem;cursor:pointer;line-height:1;z-index:10;opacity:.8;transition:opacity .15s;}
.lightbox-close:hover{opacity:1;}

/* Prev / Next nav arrows */
.lightbox-nav{
  background:none;border:none;
  color:var(--white);font-size:4rem;line-height:1;
  cursor:pointer;padding:0 1.25rem;
  opacity:.75;transition:opacity .15s;
  flex-shrink:0;user-select:none;
}
.lightbox-nav:hover:not(:disabled){opacity:1;}
.lightbox-nav:disabled{opacity:.2;cursor:default;}

/* ── Modals ──────────────────────────────────────────────── */
.modal-backdrop{display:none;position:fixed;inset:0;background:rgba(4,44,83,.45);z-index:2000;align-items:center;justify-content:center;padding:1rem;}
.modal-backdrop.open{display:flex;}
.comment-modal{background:var(--white);border-radius:10px;max-width:490px;width:100%;max-height:88vh;overflow:hidden;display:flex;flex-direction:column;}
.comment-modal-banner{height:25px;width:100%;overflow:hidden;flex-shrink:0;}
.comment-modal-banner img{width:100%;height:120px;object-fit:cover;object-position:center 40%;filter:blur(3px) brightness(.75);margin-top:-48px;transform:scale(1.06);}
.comment-modal-banner-solid{height:25px;background:var(--accent);}
.comment-modal-body{padding:1.2rem 1.4rem;overflow-y:auto;flex:1;}
.comment-modal-title{font-family:var(--font-display);font-size:1.05rem;font-style:italic;color:var(--accent-deeper);margin-bottom:.25rem;}
.comment-modal-post-name{font-family:var(--font-ui);font-size:.7rem;color:var(--ink-muted);margin-bottom:.9rem;}
.comment-name-field,.comment-textarea{width:100%;padding:.55rem .8rem;border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-body);font-size:.88rem;background:var(--accent-ghost);color:var(--ink);outline:none;transition:border-color .2s;}
.comment-name-field{margin-bottom:.6rem;}
.comment-name-field:focus,.comment-textarea:focus{border-color:var(--accent);}
.comment-textarea{resize:vertical;min-height:110px;margin-bottom:.7rem;line-height:1.7;display:block;}
.comment-review-wrap{display:none;}
.comment-review-wrap.visible{display:block;}
.comment-write-wrap.hidden{display:none;}
.review-label{font-family:var(--font-ui);font-size:.68rem;color:var(--ink-muted);margin-bottom:.45rem;letter-spacing:.04em;text-transform:uppercase;}
.review-text-box{background:var(--accent-ghost);border:1px solid var(--border);border-radius:var(--radius);padding:.7rem .9rem;font-family:var(--font-body);font-size:.88rem;color:var(--ink-soft);line-height:1.7;margin-bottom:.6rem;white-space:pre-wrap;}
.review-author-line{font-family:var(--font-ui);font-size:.72rem;color:var(--ink-muted);margin-bottom:.9rem;font-style:italic;}
.modal-btn-row{display:flex;gap:.6rem;}
.btn-commit{flex:1;padding:.58rem;background:var(--accent);color:var(--white);border:none;border-radius:var(--radius);font-family:var(--font-ui);font-size:.83rem;font-weight:500;cursor:pointer;transition:background .2s;}
.btn-commit:hover{background:var(--accent-dark);}
.btn-edit{flex:1;padding:.58rem;background:var(--white);color:var(--accent);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-ui);font-size:.83rem;font-weight:500;cursor:pointer;}
.btn-edit:hover{background:var(--accent-ghost);}
.btn-submit-comment{width:100%;padding:.58rem;background:var(--accent);color:var(--white);border:none;border-radius:var(--radius);font-family:var(--font-ui);font-size:.83rem;font-weight:500;cursor:pointer;}
.btn-submit-comment:hover{background:var(--accent-dark);}
.modal-close-btn{display:block;width:100%;padding:.45rem;margin-top:.45rem;background:none;border:none;font-family:var(--font-ui);font-size:.75rem;color:var(--ink-muted);cursor:pointer;text-align:center;}
.read-modal{background:var(--white);border-radius:10px;max-width:460px;width:100%;max-height:80vh;overflow-y:auto;}
.read-modal-banner{height:25px;width:100%;overflow:hidden;}
.read-modal-banner img{width:100%;height:120px;object-fit:cover;object-position:center 40%;filter:blur(3px) brightness(.75);margin-top:-48px;transform:scale(1.06);}
.read-modal-banner-solid{height:25px;background:var(--accent);}
.read-modal-inner{padding:1.2rem 1.4rem;}
.read-modal-author{font-family:var(--font-display);font-size:1rem;font-style:italic;color:var(--accent-deeper);}
.read-modal-date{font-family:var(--font-ui);font-size:.68rem;color:var(--ink-muted);margin-bottom:.7rem;}
.read-modal-text{font-size:.9rem;line-height:1.8;color:var(--ink-soft);border-top:1px solid var(--border);padding-top:.7rem;}

/* ── Footer ──────────────────────────────────────────────── */
.site-footer{background:var(--accent-deeper);color:var(--accent-pale);text-align:center;padding:1.1rem;}
.footer-title{font-family:var(--font-display);font-size:.88rem;font-style:italic;color:var(--accent-light);margin-bottom:.2rem;}
.site-footer p{font-family:var(--font-ui);font-size:.68rem;letter-spacing:.07em;opacity:.65;}
.post-foot-nav{display:flex;justify-content:space-between;align-items:stretch;gap:.5rem;padding:.6rem 1.25rem 1rem;background:var(--accent-deeper);border-top:1px solid rgba(255,255,255,.1);}
.foot-nav-btn{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:var(--accent-pale);font-family:var(--font-ui);font-size:.78rem;font-weight:500;letter-spacing:.03em;padding:.45rem .75rem;border-radius:var(--radius);border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.07);transition:background .15s;max-width:46%;line-height:1.3;}
.foot-nav-btn:hover{background:rgba(255,255,255,.15);}
.foot-nav-disabled{visibility:hidden;flex:0 0 46%;}
.foot-nav-prev{text-align:left;}
.foot-nav-next{text-align:right;margin-left:auto;}
.foot-nav-arrow{font-size:1.1rem;flex-shrink:0;}
.foot-nav-label{overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;}

/* ════════════════════════════════════════════════════════════
   RESPONSIVE — tablet (≤ 900px)
   ════════════════════════════════════════════════════════════ */
@media(max-width:900px){
  /* Sidebar always hidden — use dropdown panel */
  .sidebar{display:none!important;}
  .site-main{margin:0;}
}

/* ════════════════════════════════════════════════════════════
   RESPONSIVE — phone (≤ 600px)
   ════════════════════════════════════════════════════════════ */
@media(max-width:600px){
  /* Banner: shorter, smaller title */
  .banner-wrap{height:130px;}
  .banner-title{font-size:clamp(1rem,6vw,1.5rem);}
  .banner-eyebrow{display:none;}
  .banner-subtitle{font-size:.62rem;letter-spacing:.05em;}

  /* About strip: smaller text so full sentence fits */
  .about-strip p{font-size:clamp(.7rem,2.8vw,.82rem);line-height:1.45;}
  .about-strip{max-height:none;} /* let it grow as needed */
  .about-strip.collapsed{max-height:0;}

  /* Nav: hamburger right, arrow centred — correct order via grid */
  .nav-links{display:none;flex-direction:column;position:absolute;top:24px;left:0;right:0;background:var(--accent-dark);padding:.75rem 1.5rem;z-index:200;gap:.6rem;}
  .nav-links.open{display:flex;}
  .nav-hamburger{display:flex;}
  .nav-inner{position:relative;}
  /* Force hamburger to left side, arrow stays centered */
  .nav-right{order:0;}          /* left column */
  /* nav-links takes left col, toggle arrow is center, nav-right (hamburger) goes right */

  /* Two-row post header bar on mobile */
  .post-header-bar{
    flex-direction:column;
    height:auto;
    align-items:stretch;
  }
  /* Row 1: ← title → */
  .post-header-row1{
    display:flex;align-items:center;
    padding:.3rem .5rem;
    gap:.4rem;
    border-bottom:1px solid rgba(255,255,255,.12);
    min-height:34px;
  }
  /* Row 2: A-/A+ · Comment · Show Entries */
  .post-header-row2{
    display:flex;align-items:stretch;
    height:36px;
  }

  /* Row1 children */
  .post-header-title{
    display:block;
    font-size:.78rem;
    flex:1;
    min-width:0;
  }
  .mobile-nav-arrow{
    flex-shrink:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;
    font-size:1.1rem;color:var(--white);text-decoration:none;cursor:pointer;
    border-radius:4px;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.1);
    font-family:inherit;
  }
  .mobile-nav-arrow:hover:not(:disabled):not(.mobile-nav-disabled){background:rgba(255,255,255,.22);}
  .mobile-nav-arrow:disabled,.mobile-nav-disabled{color:rgba(255,255,255,.25);border-color:rgba(255,255,255,.1);background:transparent;cursor:default;}
  .font-size-controls{border-left:1px solid rgba(255,255,255,.15);padding:0 .4rem;gap:3px;height:100%;background:var(--accent-dark);}
  .font-btn{width:24px;height:24px;font-size:.72rem;}

  /* Row2 children: A-/A+ left, then Comment + Entries split remaining */
  .comment-trigger-btn{flex:1;border-left:none;border-right:1px solid rgba(255,255,255,.15);font-size:.72rem;padding:0 .5rem;}
  .entries-toggle-btn{flex:1;font-size:.72rem;padding:0 .5rem;justify-content:center;}

  /* Hide the old single-row wrappers on mobile */
  .post-header-left{display:none;}
  .post-header-right{display:none;}

  .gallery-grid{grid-template-columns:repeat(2,1fr);}

  /* ── Cancel any opt-in floats on phones — always full width ── */
  .post-body .alignleft,
  .post-body .alignright,
  .post-body figure.alignleft,
  .post-body figure.alignright,
  .post-body .wp-block-image.alignleft,
  .post-body .wp-block-image.alignright{
    float:none!important;
    clear:both!important;
    width:100%!important;
    max-width:100%!important;
    margin:1rem auto!important;
  }
  .post-body figure.alignleft img,
  .post-body figure.alignright img,
  .post-body .wp-block-image.alignleft img,
  .post-body .wp-block-image.alignright img,
  .post-body p img{
    width:100%!important;
    height:auto!important;
  }
}

/* ════════════════════════════════════════════════════════════
   LANDSCAPE PHONE (short viewport, phone-ish width)
   ════════════════════════════════════════════════════════════ */
@media(max-height:500px) and (max-width:900px){
  /* Collapse banner drastically so content is reachable */
  .banner-wrap{height:70px;}
  .banner-eyebrow{display:none;}
  .banner-subtitle{display:none;}
  .banner-divider{display:none;}
  .banner-title{font-size:1rem;}
  /* About strip starts collapsed in landscape */
  .about-strip{max-height:0!important;}
}

/* ── Two-row bar default states (JS overrides on resize) ─── */
/* Desktop (>600px): show single-row, hide two-row */
.post-header-row1{display:none;}
.post-header-row2{display:none;}

/* These are overridden to display:flex by JS on ≤600px.
   The CSS @media block below also handles initial render before JS fires. */
@media(max-width:600px){
  .post-header-row1{display:flex!important;}
  .post-header-row2{display:flex!important;}
  .post-header-left{display:none!important;}
  .post-header-right{display:none!important;}
}
