/*
Theme Name: SACruise-v7.06.3f
Theme URI: https://fonh.com
Author: Chris & Cathy
Description: From Buenos Aires to Italy — Our 40th Anniversary travel journal
Version: 7.06.3f
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 3rem;max-width:390px;width:100%;text-align:center;border:1px solid var(--border);position:relative;}
#name-prompt-cancel{position:absolute;top:.65rem;right:.75rem;background:none;border:none;cursor:pointer;font-size:1rem;color:var(--ink-muted);opacity:.5;line-height:1;padding:.2rem .3rem;}
#name-prompt-cancel:hover{opacity:1;}
.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:1rem;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-block{position:absolute;top:8px;left:12px;display:flex;flex-direction:column;align-items:flex-start;gap:2px;}
.banner-visitor-name{font-family:var(--font-ui);font-size:.72rem;color:#e8f4ff;font-weight:400;letter-spacing:.05em;}
#banner-not-me{background:none;border:none;padding:0;margin:0;cursor:pointer;font-family:var(--font-ui);font-size:.58rem;color:var(--accent-pale);font-weight:300;letter-spacing:.05em;opacity:.55;text-align:left;}
#banner-not-me:hover{opacity:1;text-decoration:underline;}
.banner-version{position:absolute;top:8px;right:12px;font-family:var(--font-ui);font-size:1.15rem;color:var(--accent-pale);font-weight:300;letter-spacing:.06em;opacity:.6;}
.banner-version-user{font-size:.72rem;letter-spacing:.09em;opacity:.8;}
/* Nav debug toggle */
.nav-debug-toggle{display:flex;align-items:center;gap:.3rem;cursor:pointer;font-family:var(--font-ui);font-size:.65rem;color:var(--ink-muted);margin-right:.25rem;}
.nav-debug-toggle input{cursor:pointer;}
.nav-debug-text{letter-spacing:.06em;transition:color .2s;}
.debug-mode-active .nav-debug-text{color:#FFD700;font-weight:700;}
/* Admin console tabs */
.admin-tabs{display:flex;border-bottom:2px solid var(--border);background:var(--white);flex-shrink:0;}
.admin-tab{flex:1;padding:.55rem .5rem;font-family:var(--font-ui);font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;color:var(--ink-muted);transition:all .15s;}
.admin-tab.active{color:var(--accent);border-bottom-color:var(--accent);}
.admin-tab:hover:not(.active){color:var(--ink);}
.admin-tab-panel{display:none;overflow-y:auto;padding:1rem;}
.admin-tab-panel.active{display:block;}
/* Admin console controls */
.admin-console-section{margin-bottom:1.5rem;}
.admin-console-heading{font-family:var(--font-ui);font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-muted);margin:0 0 .6rem;padding-bottom:.3rem;border-bottom:1px solid var(--border);}
.admin-console-toggle{display:flex;align-items:center;gap:.5rem;font-family:var(--font-ui);font-size:.8rem;color:var(--ink);cursor:pointer;}
.admin-console-toggle input{cursor:pointer;width:16px;height:16px;}
.admin-size-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;}
.admin-size-label{font-family:var(--font-ui);font-size:.75rem;color:var(--ink);flex:1;}
.admin-size-btn{background:var(--accent);color:var(--white);border:none;font-family:var(--font-ui);font-size:.72rem;font-weight:600;padding:3px 10px;border-radius:4px;cursor:pointer;min-width:32px;}
.admin-size-btn:hover{background:var(--accent-deeper);}
.admin-size-val{font-family:var(--font-ui);font-size:.72rem;color:var(--ink-muted);min-width:3.5rem;text-align:center;}
/* Commenters tab — flex-column layout so toolbar doesn't scroll */
#tab-commenters{display:none;flex-direction:column;overflow:hidden;padding:0;}
#tab-commenters.active{display:flex;}
.admin-commenters-toolbar{flex-shrink:0;display:flex;align-items:center;gap:.4rem;padding:.35rem .75rem;border-bottom:1px solid var(--border);background:var(--white);}
.admin-sort-label{font-family:var(--font-ui);font-size:.62rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-muted);white-space:nowrap;}
.admin-sort-btn-group{display:flex;gap:.2rem;}
.admin-sort-btn{font-family:var(--font-ui);font-size:.63rem;font-weight:600;padding:.18rem .42rem;border-radius:3px;border:1px solid var(--border);background:var(--white);color:var(--ink-muted);cursor:pointer;transition:background .12s,color .12s,border-color .12s;white-space:nowrap;line-height:1.4;}
.admin-sort-btn:hover{background:var(--bg-soft);color:var(--ink);}
.admin-sort-btn.active{background:var(--accent);border-color:var(--accent);color:var(--white);}
/* Commenters body scroll area */
.admin-commenters-body{overflow-y:auto;flex:1;padding:.75rem;}
/* Activity Summary tab */
.admin-activity-body{overflow-y:auto;padding:.75rem;}
.activity-month{margin-bottom:.5rem;}
.activity-month-toggle{width:100%;text-align:left;background:var(--accent-ghost);border:none;border-radius:var(--radius);padding:.4rem .75rem;font-family:var(--font-ui);font-size:.82rem;font-weight:600;color:var(--accent-deeper);cursor:pointer;display:flex;justify-content:space-between;align-items:center;}
.activity-month-toggle:hover{background:var(--accent-pale);}
.activity-month-body{padding:.25rem 0 .25rem .75rem;}
.activity-week{margin-bottom:.35rem;}
.activity-week-toggle{width:100%;text-align:left;background:none;border:none;border-left:2px solid var(--border);padding:.3rem .6rem;font-family:var(--font-ui);font-size:.78rem;font-weight:600;color:var(--ink);cursor:pointer;display:flex;justify-content:space-between;align-items:center;}
.activity-week-toggle:hover{background:var(--accent-ghost);}
.activity-week-body{padding:.15rem 0 .15rem .75rem;}
.activity-day{margin-bottom:.5rem;border-left:2px solid var(--border-soft);padding:.35rem .6rem;}
.activity-day-date{font-family:var(--font-ui);font-size:.75rem;font-weight:600;color:var(--accent-deeper);margin-bottom:.3rem;}
.activity-day-quiet{font-family:var(--font-ui);font-size:.72rem;color:var(--ink-muted);font-style:italic;}
.activity-visitor{font-family:var(--font-ui);font-size:.75rem;color:var(--ink);margin-bottom:.2rem;}
.activity-visitor-name{font-weight:600;}
.activity-post{font-family:var(--font-ui);font-size:.7rem;color:var(--ink-muted);padding-left:.75rem;}
.activity-comment{font-family:var(--font-ui);font-size:.7rem;color:var(--ink);padding-left:.75rem;font-style:italic;border-left:2px solid var(--accent-pale);margin:.15rem 0 .15rem .5rem;}
.activity-new-post{font-family:var(--font-ui);font-size:.72rem;color:#00897B;font-weight:600;margin-bottom:.2rem;}
.activity-empty{padding:2rem;text-align:center;color:var(--ink-muted);font-family:var(--font-ui);font-size:.82rem;font-style:italic;}
/* Collapsible section cards (MCP + PC) */
.admin-csect{border:1px solid var(--border);border-radius:6px;margin-bottom:.65rem;overflow:hidden;}
.admin-csect-hdr{display:flex;align-items:center;gap:.45rem;padding:.45rem .65rem;cursor:pointer;user-select:none;background:var(--bg-soft);}
.admin-csect-hdr:hover{background:var(--bg-hover,#eef0f5);}
.admin-csect-chevron{font-size:1.25rem;color:var(--accent);flex-shrink:0;line-height:1;width:.9rem;text-align:center;position:relative;}
.admin-csect-hdr .admin-csect-chevron{top:-0.14rem;}
.admin-cauthor-hdr .admin-csect-chevron{top:-0.05rem;}
.admin-csect-title{font-family:var(--font-ui);font-size:.62rem;font-weight:700;letter-spacing:.11em;text-transform:uppercase;color:var(--ink-muted);flex:1;}
.admin-csect-summary{display:flex;align-items:center;gap:.5rem;font-family:var(--font-ui);font-size:.72rem;color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:55%;}
.admin-csect-count{font-weight:700;color:var(--accent);margin-left:.35rem;flex-shrink:0;}
.admin-csect-body{padding:.5rem .65rem .6rem;}
/* MCP list rows */
.admin-mcp-row{display:flex;align-items:center;gap:.5rem;padding:.18rem 0;}
.admin-mcp-post{font-family:var(--font-ui);font-size:.73rem;color:var(--ink);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.admin-mcp-right{display:flex;align-items:center;gap:.4rem;flex-shrink:0;}
.admin-mcp-bar-wrap{display:inline-block;height:4px;background:var(--border);border-radius:2px;overflow:hidden;flex-shrink:0;vertical-align:middle;}
.admin-mcp-bar{display:block;height:100%;background:var(--accent);border-radius:2px;opacity:.8;}
.admin-mcp-count{font-family:var(--font-ui);font-size:.65rem;font-weight:700;color:var(--accent);min-width:1.4rem;text-align:right;}
/* Author rows inside PC */
.admin-cauthor-sect{border-bottom:1px solid var(--border-soft,#e8eaf0);}
.admin-cauthor-sect:last-child{border-bottom:none;}
.admin-cauthor-hdr{display:flex;align-items:center;gap:.4rem;padding:.45rem .1rem;cursor:pointer;user-select:none;}
.admin-cauthor-hdr:hover .admin-cauthor-name{color:var(--accent);}
.admin-cauthor-name{font-family:var(--font-display);font-size:.92rem;font-weight:600;color:var(--accent-deeper);}
.admin-cauthor-count{font-family:var(--font-ui);font-size:.68rem;color:var(--ink-muted);font-weight:400;}
.admin-cauthor-body{padding:.1rem 0 .5rem .3rem;}
/* Comment block */
.admin-cmt-block{padding:.35rem 0;border-bottom:1px solid var(--border-soft,#e8eaf0);}
.admin-cmt-block:last-child{border-bottom:none;}
.admin-cmt-hdr-row{display:flex;justify-content:space-between;align-items:baseline;gap:.4rem;margin-bottom:.2rem;}
.admin-cmt-title{flex:1;min-width:0;font-family:var(--font-ui);font-size:.78rem;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.admin-cmt-date{flex-shrink:0;font-family:var(--font-ui);font-size:.68rem;color:var(--ink-muted);white-space:nowrap;}
.admin-cmt-line{display:flex;align-items:flex-start;gap:.3rem;margin-top:.1rem;min-width:0;}
.admin-cmt-badge{flex-shrink:0;min-width:var(--cmt-badge-w,5rem);font-family:var(--font-ui);font-size:.7rem;font-weight:700;font-style:normal;}
.admin-cmt-text-wrap{flex:1;min-width:0;overflow:hidden;}
.admin-cmt-text{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-style:italic;font-size:.74rem;color:var(--ink-soft);line-height:1.5;word-break:break-word;width:100%;}
.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;min-height:24px;height:auto;}
.nav-links{display:flex;gap:1.5rem;list-style:none;align-items:center;margin:0;padding:0;height:100%;}
.nav-links li{display:flex;align-items:center;}
.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 .75rem 0 .75rem;}
.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;flex:1;}
.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;}
.desk-nav-arrow{flex-shrink:0;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;font-size:1rem;color:var(--white);background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);border-radius:4px;cursor:pointer;transition:background .15s;font-family:inherit;}
.desk-nav-arrow:hover:not(:disabled):not(.desk-nav-disabled){background:rgba(255,255,255,.25);}
.desk-nav-arrow:disabled,.desk-nav-disabled{color:rgba(255,255,255,.22);border-color:rgba(255,255,255,.1);background:transparent;cursor:default;}
.nav-stats-btn{background:none;border:none;color:var(--accent-light);font-size:.85rem;cursor:pointer;padding:2px 4px;opacity:.8;transition:opacity .15s;}
.nav-stats-btn:hover{opacity:1;}
.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;
}

/* ── Admin password + stats modals ──────────────────────── */
.admin-pw-box{background:var(--white);border-radius:10px;width:calc(100% - 2rem);max-width:340px;overflow:hidden;box-shadow:0 8px 32px rgba(4,44,83,.22);}
.admin-pw-header{background:#00897B;color:var(--white);display:flex;align-items:center;justify-content:space-between;padding:.6rem .85rem;font-family:var(--font-ui);font-size:.65rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;}
.admin-pw-body{padding:1.25rem 1.25rem 1.5rem;display:flex;flex-direction:column;gap:.75rem;}
.admin-pw-body p{font-family:var(--font-ui);font-size:.82rem;color:var(--ink-muted);margin:0;}
.admin-pw-body input{width:100%;padding:.55rem .85rem;border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-ui);font-size:.9rem;color:var(--ink);background:var(--accent-ghost);outline:none;box-sizing:border-box;}
.admin-pw-input-wrap{position:relative;display:flex;align-items:center;}
.admin-pw-input-wrap input{padding-right:2.5rem;width:100%;box-sizing:border-box;}
.admin-pw-eye{position:absolute;right:.5rem;background:none;border:none;cursor:pointer;font-size:1rem;color:var(--ink-muted);padding:2px 4px;line-height:1;opacity:.7;}
.admin-pw-eye:hover{opacity:1;}
.admin-pw-error{font-family:var(--font-ui);font-size:.75rem;color:#c0392b;min-height:1rem;}
.admin-pw-links{display:flex;justify-content:space-between;margin-top:.25rem;}
.admin-pw-link{font-family:var(--font-ui);font-size:.72rem;color:var(--accent);text-decoration:none;cursor:pointer;}
.admin-pw-link:hover{text-decoration:underline;}
.admin-pw-hint{font-family:var(--font-ui);font-size:.75rem;color:var(--ink-muted);background:var(--accent-ghost);border-radius:4px;padding:.35rem .6rem;margin-top:.25rem;line-height:1.4;}
.admin-stats-box{background:var(--white);border-radius:10px;width:calc(100% - 2rem);max-width:780px;min-height:500px;max-height:90vh;height:auto;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 32px rgba(4,44,83,.22);position:relative;user-select:none;}
/* Mobile debug indicator — desktop only shows nothing */
#mobile-debug-indicator{display:none!important;}
/* Mobile flyout — hidden on desktop */
.mobile-flyout{display:none;}
.admin-resize-handle{position:absolute;z-index:10;}
.admin-resize-n {top:0;left:8px;right:8px;height:5px;cursor:n-resize;}
.admin-resize-s {bottom:0;left:8px;right:8px;height:5px;cursor:s-resize;}
.admin-resize-e {top:8px;bottom:8px;right:0;width:5px;cursor:e-resize;}
.admin-resize-w {top:8px;bottom:8px;left:0;width:5px;cursor:w-resize;}
.admin-resize-ne{top:0;right:0;width:12px;height:12px;cursor:ne-resize;}
.admin-resize-nw{top:0;left:0;width:12px;height:12px;cursor:nw-resize;}
.admin-resize-se{bottom:0;right:0;width:12px;height:12px;cursor:se-resize;}
.admin-resize-sw{bottom:0;left:0;width:12px;height:12px;cursor:sw-resize;}
.admin-stats-header{cursor:grab;}
.admin-stats-header:active{cursor:grabbing;}
.admin-stats-header{background:var(--accent-deeper);color:var(--white);display:flex;align-items:center;justify-content:space-between;padding:.65rem 1rem;font-family:var(--font-ui);font-size:.65rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;flex-shrink:0;}
.admin-stats-close{background:none;border:none;color:var(--white);font-size:1.4rem;line-height:1;cursor:pointer;padding:0 2px;opacity:.8;}
.admin-stats-close:hover{opacity:1;}
.admin-stats-pw-btn{background:none;border:1px solid rgba(255,255,255,.3);color:var(--white);font-size:.85rem;line-height:1;cursor:pointer;padding:2px 7px;border-radius:4px;opacity:.8;}
.admin-stats-pw-btn:hover{opacity:1;background:rgba(255,255,255,.15);}
.admin-stats-body{overflow-y:auto;flex:1;padding:1rem;}
.admin-stats-inner{display:flex;flex:1;overflow:hidden;position:relative;flex-direction:column;}
.admin-comment-panel{position:absolute;top:12px;right:0;bottom:20px;width:0;overflow:hidden;transition:width .3s ease;display:flex;flex-direction:column;background:var(--white);border-radius:0 0 8px 0;box-shadow:-4px 0 16px rgba(4,44,83,.18),0 4px 10px rgba(4,44,83,.12);border-bottom:2px solid var(--accent-pale);z-index:10;}
.admin-comment-panel.open{width:55%;}
.admin-comment-panel-header{background:var(--accent-deeper);color:var(--white);padding:.55rem .75rem;font-family:var(--font-ui);font-size:.65rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.2);}
.admin-comment-panel-close{background:none;border:none;color:var(--white);font-size:1.1rem;cursor:pointer;opacity:.8;padding:0;}
.admin-comment-panel-close:hover{opacity:1;}
.admin-comment-panel-post{font-family:var(--font-display);font-size:.82rem;font-style:italic;color:var(--accent-deeper);padding:.5rem .75rem .2rem;flex-shrink:0;}
.admin-comment-panel-date{font-family:var(--font-ui);font-size:.65rem;color:var(--ink-muted);padding:0 .75rem .4rem;flex-shrink:0;}
.admin-comment-panel-text{font-family:var(--font-ui);font-size:.82rem;color:var(--ink);padding:.4rem .75rem .75rem;overflow-y:auto;flex:1;line-height:1.55;font-style:italic;max-height:60vh;}
.admin-comment-ellipsis{cursor:pointer;font-size:.68rem;font-family:var(--font-ui);background:none;border:none;padding:0;}
.btn-read-more{background:var(--accent);color:var(--white);border:none;font-family:var(--font-ui);font-size:.65rem;font-weight:600;padding:2px 8px;border-radius:3px;cursor:pointer;flex-shrink:0;margin-left:auto;vertical-align:middle;}
.btn-read-more:hover{background:var(--accent-deeper);}
.admin-stats-table{width:100%;border-collapse:collapse;font-family:var(--font-ui);font-size:.78rem;}
.admin-stats-table th{background:var(--accent-ghost);color:var(--accent-deeper);font-weight:600;padding:.45rem .75rem;text-align:center;border-bottom:2px solid var(--border);}
.admin-stats-table th.left{text-align:left;}
.admin-stats-table td{padding:.45rem .75rem;border-bottom:1px solid var(--border-soft);color:var(--ink);text-align:center;}
.admin-stats-table td.left{text-align:left;}
.admin-stats-table tr:hover td{background:var(--accent-ghost);cursor:pointer;}
.admin-stats-table .role-section-head{background:var(--accent-ghost);font-size:.68rem;font-weight:700;letter-spacing:.08em;padding:.25rem .75rem;border-bottom:1px solid var(--border);text-align:left;}
.role-icon-btn{background:none;border:none;cursor:pointer;padding:0;display:inline-flex;gap:3px;align-items:center;opacity:.85;}
.role-icon-btn:hover{opacity:1;}
/* Role popup */
.role-popup-backdrop{position:fixed;inset:0;background:rgba(4,44,83,.45);z-index:9999;display:flex;align-items:center;justify-content:center;}
.role-popup{background:var(--white);border-radius:12px;padding:1.25rem 1.5rem;width:280px;box-shadow:0 8px 32px rgba(4,44,83,.22);}
.role-popup-name{font-family:var(--font-ui);font-size:1rem;font-weight:600;margin-bottom:1rem;display:flex;align-items:center;gap:.4rem;}
.role-popup-row{display:flex;align-items:center;gap:.6rem;padding:.45rem 0;border-bottom:1px solid var(--border-soft);}
.role-popup-row:last-of-type{border-bottom:none;}
.role-popup-label{flex:1;font-family:var(--font-ui);font-size:.85rem;}
.role-popup-sub{font-family:var(--font-ui);font-size:.7rem;color:var(--ink-muted);}
.role-popup-btns{display:flex;gap:.5rem;margin-top:1rem;}
.role-popup-btns button{flex:1;padding:.45rem;border-radius:var(--radius);border:1px solid var(--border);font-family:var(--font-ui);font-size:.82rem;cursor:pointer;text-align:center;}
.role-popup-btns .btn-cancel{background:var(--accent-ghost);color:var(--ink);}
.role-popup-btns .btn-save{background:var(--accent);color:var(--white);border-color:var(--accent);}
/* Phone number inline editor */
.phone-cell{display:flex;align-items:center;gap:4px;min-width:110px;}
.phone-display{font-family:var(--font-ui);font-size:.72rem;color:var(--ink);cursor:pointer;padding:2px 4px;border-radius:3px;border:1px solid transparent;}
.phone-display:hover{border-color:var(--border);background:var(--accent-ghost);}
.phone-display.empty{color:var(--ink-muted);font-style:italic;}
.phone-input-wrap{display:none;align-items:center;gap:3px;}
.phone-input-wrap input{width:110px;padding:2px 5px;font-family:var(--font-ui);font-size:.72rem;border:1px solid var(--accent);border-radius:3px;}
.phone-save-btn,.phone-cancel-btn{background:none;border:none;cursor:pointer;font-size:.75rem;padding:1px 3px;}
.phone-save-btn{color:#00897B;}
.phone-cancel-btn{color:var(--ink-muted);}
/* Notification status */
.notif-subscribed{color:#00897B;font-size:.78rem;}
.notif-opted-out{color:var(--ink-muted);font-size:.78rem;}
.notif-none{color:var(--ink-muted);font-size:.78rem;font-style:italic;}
/* Banner role badge */
.banner-role-badge{font-family:var(--font-ui);font-size:.52rem;font-variant:small-caps;letter-spacing:.08em;color:#c9a227;font-weight:600;vertical-align:middle;margin-left:.3rem;}
.admin-visitor-detail{margin-top:1rem;}
.admin-back-btn{background:none;border:1px solid var(--accent);color:var(--accent);font-family:var(--font-ui);font-size:.72rem;padding:3px 10px;border-radius:4px;cursor:pointer;margin-bottom:.75rem;}
.admin-back-btn:hover{background:var(--accent-ghost);}
.admin-detail-section{margin-bottom:1rem;}
.admin-detail-heading{font-family:var(--font-ui);font-size:.65rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:.4rem;}
.admin-detail-item{font-family:var(--font-ui);font-size:.78rem;color:var(--ink);padding:.3rem 0;border-bottom:1px solid var(--border-soft);}
.admin-detail-comment{font-style:italic;color:var(--ink-soft);font-size:.74rem;margin-top:.15rem;}

/* ── Visited post indicator in sidebar + modal ───────────── */
.older-post-item.fonh-visited .older-post-title{color:var(--ink-muted);}
.older-post-item.fonh-visited .older-post-date{color:var(--border);}
.older-post-item.fonh-visited .older-post-excerpt{color:var(--border);}
.older-post-item.fonh-visited{background:var(--paper)!important;}
.older-post-item.fonh-visited:hover{background:var(--accent-ghost)!important;}

/* ── 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);}
.sidebar-collapse-btn{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.35);border-radius:4px;color:var(--white);font-size:.75rem;padding:1px 5px;cursor:pointer;line-height:1;transition:background .15s;}
.sidebar-collapse-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);}
/* Collapsed sidebar post items — single line with truncated title + count + date */
.sidebar-posts-collapsed .older-post-item{padding:.3rem .65rem;display:flex;align-items:baseline;gap:.3rem;}
.sidebar-posts-collapsed .older-post-date,.sidebar-posts-collapsed .older-post-excerpt{display:none;}
.sidebar-posts-collapsed .older-post-title{font-size:.68rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0;font-style:italic;}
.sidebar-posts-collapsed .older-post-comment-count{font-size:.62rem;font-weight:700;color:#1565C0;flex-shrink:0;white-space:nowrap;}
.sidebar-posts-collapsed .older-post-date-short{font-size:.62rem;color:var(--ink-muted);flex-shrink:0;white-space:nowrap;font-style:normal;}
/* Comment count badge in normal view (admin only) */
.older-post-comment-count{font-family:var(--font-ui);font-size:.76rem;font-weight:700;color:#2ba632;margin-top:.15rem;letter-spacing:.01em;line-height:1.2;}
.cmt-cnt-num{font-size:.76rem;}
.cmt-cnt-lbl{font-size:.76rem;text-transform:uppercase;letter-spacing:.04em;}
.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;}
/* Helper class — add 'fonh-portrait' in WP editor to cap a tall image on mobile */
.post-body img.fonh-portrait,
.post-body figure.fonh-portrait img,
.post-body .wp-block-image.fonh-portrait img{
  max-height:60vh;
  width:auto!important;
  max-width:100%!important;
  margin-left:auto;margin-right:auto;
}

/* ── 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);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:.88rem;font-weight:600;color:var(--accent-dark);}
.comment-date-small{font-family:var(--font-ui);font-size:.72rem;color:var(--ink-muted);margin-left:.35rem;}
.no-comments-link{display:inline-block;font-family:var(--font-ui);font-size:.85rem;font-style:normal;font-weight:600;color:var(--white);background:var(--accent);padding:.35rem .85rem;border-radius:4px;text-decoration:none;transition:background .2s;}
.no-comments-link:hover{background:var(--accent-deeper);}
.comment-edited-badge{font-family:var(--font-ui);font-size:.6rem;color:var(--ink-muted);font-style:italic;background:var(--border-soft);border-radius:3px;padding:1px 5px;margin-left:.3rem;}
.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;cursor:pointer;}
.comment-actions{display:flex;align-items:center;gap:.75rem;margin-top:3px;}
.comment-read-more{font-family:var(--font-ui);font-size:.64rem;color:var(--accent);cursor:pointer;}
.comment-reply-btn{background:none;border:none;font-family:var(--font-ui);font-size:.64rem;color:var(--ink-muted);cursor:pointer;padding:0;}
.comment-reply-btn:hover{color:var(--accent);}
.comment-edit-btn{background:none;border:none;font-family:var(--font-ui);font-size:.64rem;color:var(--ink-muted);cursor:pointer;padding:0;display:none;}
.comment-edit-btn:hover{color:var(--accent);}
.comment-edit-btn.visible{display:inline;}
.comment-edit-form{margin-top:.5rem;}
.comment-edit-textarea{width:100%;box-sizing:border-box;font-family:var(--font-ui);font-size:.82rem;padding:.4rem .6rem;border:1px solid var(--border);border-radius:var(--radius);resize:vertical;color:var(--ink);background:var(--accent-ghost);}
.comment-edit-actions{display:flex;align-items:center;gap:.5rem;margin-top:.3rem;}
.comment-edit-save{background:var(--accent);color:var(--white);border:none;font-family:var(--font-ui);font-size:.72rem;padding:3px 10px;border-radius:4px;cursor:pointer;}
.comment-edit-cancel{background:none;border:1px solid var(--border);font-family:var(--font-ui);font-size:.72rem;padding:3px 10px;border-radius:4px;cursor:pointer;color:var(--ink-muted);}
.comment-edit-msg{font-family:var(--font-ui);font-size:.68rem;color:var(--ink-muted);}
.comment-edit-timer{font-family:var(--font-ui);font-size:.68rem;color:var(--ink-muted);margin-left:auto;display:none;}
.debug-mode-active .comment-edit-timer{display:inline;}
.comment-edit-timer.urgent{color:#c0392b;font-weight:600;}
.comment-inline-timer{font-family:var(--font-ui);font-size:.62rem;color:var(--ink-muted);margin-left:.4rem;display:none;}
.comment-inline-timer.urgent{color:#c0392b;font-weight:600;}
.debug-mode-active .comment-inline-timer{display:inline;}
/* Admin debug toggle */
/* Admin size controls above */
/* Timer settings */
.admin-debug-only{display:none;}
.debug-mode-active .admin-debug-only{display:block;}
.admin-timer-row{display:flex;gap:1.5rem;margin-bottom:.75rem;}
.admin-timer-radio{display:flex;align-items:center;gap:.35rem;font-family:var(--font-ui);font-size:.78rem;color:var(--ink);cursor:pointer;}
.admin-timer-radio input{cursor:pointer;width:14px;height:14px;}
.admin-timer-inputs{display:none;padding:.6rem .75rem;background:var(--accent-ghost);border-radius:6px;border:1px solid var(--border);}
.admin-timer-inputs.visible{display:block;}
.admin-timer-field{margin-bottom:.6rem;}
.admin-timer-label{display:block;font-family:var(--font-ui);font-size:.72rem;color:var(--ink-muted);margin-bottom:.25rem;}
.admin-timer-input-row{display:flex;align-items:center;gap:.5rem;}
.admin-timer-input{font-family:var(--font-ui);font-size:.8rem;padding:3px 8px;border:1px solid var(--border);border-radius:4px;width:70px;color:var(--ink);}
.admin-timer-default{font-family:var(--font-ui);font-size:.65rem;color:var(--ink-muted);font-style:italic;}
.admin-timer-apply{margin-top:.5rem;background:var(--accent);color:var(--white);border:none;font-family:var(--font-ui);font-size:.72rem;font-weight:600;padding:4px 14px;border-radius:4px;cursor:pointer;}
.admin-timer-apply:hover{background:var(--accent-deeper);}
.admin-timer-applied{font-family:var(--font-ui);font-size:.68rem;color:#2ba632;margin-left:.5rem;}
/* Edit inactivity warning modal */
.edit-warning-box{background:var(--white);border-radius:12px;padding:2rem 2rem 1.5rem;max-width:380px;width:calc(100% - 3rem);text-align:center;box-shadow:0 8px 32px rgba(4,44,83,.22);}
.edit-warning-icon{font-size:2rem;margin-bottom:.5rem;}
.edit-warning-title{font-family:var(--font-serif);font-size:1.1rem;color:var(--ink);margin:0 0 .75rem;}
.edit-warning-msg{font-family:var(--font-ui);font-size:.82rem;color:var(--ink);line-height:1.5;margin:0 0 .4rem;}
.edit-warning-sub{font-family:var(--font-ui);font-size:.74rem;color:var(--ink-muted);line-height:1.5;margin:0 0 1.25rem;}
.edit-warning-actions{display:flex;gap:.75rem;justify-content:center;}
.edit-warning-save{background:var(--accent);color:var(--white);border:none;font-family:var(--font-ui);font-size:.78rem;font-weight:600;padding:6px 18px;border-radius:5px;cursor:pointer;}
.edit-warning-save:hover{background:var(--accent-deeper);}
.edit-warning-keep{background:none;border:1px solid var(--border);font-family:var(--font-ui);font-size:.78rem;padding:6px 18px;border-radius:5px;cursor:pointer;color:var(--ink-muted);}
.edit-warning-keep:hover{border-color:var(--accent);color:var(--accent);}
.comment-reply-form{margin:.4rem 0 .4rem 1.75rem;padding-left:.75rem;border-left:3px solid var(--accent-pale);}
.comment-reply-textarea{width:100%;box-sizing:border-box;font-family:var(--font-ui);font-size:.82rem;padding:.4rem .6rem;border:1px solid var(--border);border-radius:var(--radius);resize:vertical;color:var(--ink);background:var(--accent-ghost);}
.comment-reply-actions{display:flex;align-items:center;gap:.5rem;margin-top:.3rem;}
.comment-reply-submit{background:var(--accent);color:var(--white);border:none;font-family:var(--font-ui);font-size:.72rem;padding:3px 10px;border-radius:4px;cursor:pointer;}
.comment-reply-cancel{background:none;border:1px solid var(--border);font-family:var(--font-ui);font-size:.72rem;padding:3px 10px;border-radius:4px;cursor:pointer;color:var(--ink-muted);}

/* ── 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;}
  /* Cap tall portrait images so they don't consume the whole screen */
  .post-body img,.post-body figure img,.post-body .wp-block-image img{
    max-height:70vh;
    width:auto!important;
    max-width:100%!important;
  }
  .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: triangle centred, hamburger fixed at top-right — flyout popup */
  .nav-links{display:none;}  /* hide normal nav links on mobile */
  .nav-inner{position:relative;display:flex;align-items:center;justify-content:center;padding:0 .75rem;}
  .nav-about-toggle{margin:0 auto;}
  .nav-right{position:static;display:flex;align-items:center;gap:.4rem;}
  /* Hamburger fixed top-right in banner area */
  .nav-hamburger{
    display:flex;
    position:fixed;
    top:.55rem;
    right:.75rem;
    z-index:500;
    background:rgba(4,44,83,.55);
    border-radius:4px;
    padding:5px;
  }
  /* Flyout popup — appears to left of hamburger */
  .mobile-flyout{
    display:none;
    position:fixed;
    top:1.2rem;
    right:3.2rem;
    z-index:499;
    background:#2B7FC4;
    border-radius:6px;
    box-shadow:0 4px 16px rgba(0,0,0,.35);
    padding:.35rem 0;
    width:max-content;
    flex-direction:column;
  }
  .mobile-flyout.open{display:flex;}
  .mobile-flyout a,.mobile-flyout button{
    display:block;
    font-family:var(--font-ui);
    font-size:.52rem;
    font-weight:600;
    letter-spacing:.08em;
    text-transform:uppercase;
    color:var(--white)!important;
    padding:.35rem .7rem;
    text-decoration:none;
    background:none!important;
    border:none!important;
    cursor:pointer;
    text-align:left;
    width:100%;
    transition:background .15s;
  }
  /* Hide debug toggle from nav bar on mobile — it moves to flyout */
  #nav-debug-toggle{display:none!important;}
  .mobile-flyout a:hover,.mobile-flyout button:hover{background:rgba(255,255,255,.15)!important;}
  .flyout-debug-active{background:rgba(255,255,255,.18)!important;color:#7FD4A0!important;}
  /* "Not [Name]?" — secondary action, visually separated */
  #flyout-not-me{
    opacity:.65;
    font-size:.46rem!important;
    letter-spacing:.06em!important;
    border-top:1px solid rgba(255,255,255,.2)!important;
    margin-top:.2rem!important;
    padding-top:.5rem!important;
  }
  #flyout-not-me:hover{opacity:1;}

  /* 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;}
}
