/* ============================================================
   Things To Do In Fajardo - shared styles (magazine redesign)
   Tokens are canonical. Do not edit without a documented decision.
   Old token names (--teal, --coral, --sand, --warm-white) are kept
   as ALIASES so existing inline var() usages on built pages keep
   working; they now resolve to the magazine palette.
   ============================================================ */
:root{
  /* magazine palette */
  --paper:#F7F3EC;
  --paper-2:#F1EBDF;
  --ink:#1A1712;
  --ink-soft:#5A5345;
  --muted:#8A8270;
  --accent:#C24A2A;        /* terracotta */
  --accent-deep:#9A3A1F;
  --bay:#12B58E;           /* single bio-bay accent */
  --line:rgba(26,23,18,.14);
  --line-soft:rgba(26,23,18,.08);

  /* legacy aliases (existing pages reference these inline) */
  --teal:var(--accent);
  --teal-deep:var(--accent-deep);
  --coral:var(--accent);
  --warm-white:var(--paper);
  --sand:var(--paper-2);
  --ink-soft:#5A5345;
  --border:var(--line);

  --radius:14px;
  --radius-sm:10px;
  --shadow-sm:0 1px 2px rgba(26,23,18,.06);
  --shadow-lg:0 14px 36px rgba(26,23,18,.12);
  --maxw:1180px;
  --font-display:'DM Serif Display',Georgia,'Times New Roman',serif;
  --font-body:'Archivo',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--font-body);color:var(--ink);
  background:var(--paper);line-height:1.65;font-size:17px;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:400;line-height:1.06;color:var(--ink);margin:0 0 .5em}
h1{font-size:clamp(2.4rem,5vw,3.6rem);letter-spacing:-.01em}
h2{font-size:clamp(1.8rem,3.5vw,2.5rem)}
h3{font-size:clamp(1.25rem,2.5vw,1.55rem)}
p{margin:0 0 1.15em}
a{color:var(--ink);text-decoration:none;border-bottom:1.5px solid var(--accent)}
a:hover{color:var(--accent)}
img{max-width:100%;height:auto;display:block}
:focus-visible{outline:3px solid var(--accent);outline-offset:3px}

/* a11y skip link */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:.75rem 1rem;z-index:1000}
.skip-link:focus{left:8px;top:8px}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* header / nav (paper masthead, ink rule under it) */
.site-header{position:sticky;top:0;z-index:100;background:rgba(247,243,236,.94);backdrop-filter:blur(8px);border-bottom:1.5px solid var(--ink)}
.nav{display:flex;align-items:center;justify-content:space-between;height:66px}
.brand{display:flex;align-items:center;gap:.55rem;font-family:var(--font-display);font-weight:400;font-size:1.4rem;color:var(--ink);text-decoration:none;border:0;line-height:1}
.brand:hover{color:var(--ink)}
.bio-dot{width:12px;height:12px;border-radius:50%;background:var(--bay);box-shadow:0 0 0 0 rgba(18,181,142,.55);animation:glow 2.6s ease-in-out infinite;flex:none}
@keyframes glow{0%,100%{box-shadow:0 0 0 0 rgba(18,181,142,.5)}50%{box-shadow:0 0 0 7px rgba(18,181,142,0)}}
.nav-links{display:flex;gap:1.5rem;list-style:none;margin:0;padding:0}
.nav-links a{color:var(--ink);text-decoration:none;border:0;font-family:var(--font-body);font-size:.9rem;font-weight:500}
.nav-links a:hover{color:var(--accent)}
.nav-links a[aria-current="page"]{color:var(--accent)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:6px;color:var(--ink)}
.nav-toggle svg{width:26px;height:26px}

/* buttons (never labeled "Book Now") */
.btn{display:inline-block;font-family:var(--font-body);font-weight:600;font-size:.95rem;padding:.8rem 1.4rem;border-radius:var(--radius-sm);text-decoration:none;border:0;cursor:pointer;transition:transform .15s ease,background .15s ease}
.btn-primary{background:var(--accent);color:#fff;border:0}
.btn-primary:hover{background:var(--accent-deep);color:#fff;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}

/* sections / layout */
.section{padding:3.25rem 0}
.section--sand{background:var(--paper-2);border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.lede{font-size:1.12rem;line-height:1.6;color:var(--ink-soft);max-width:62ch}
.eyebrow{font-family:var(--font-body);font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin:0 0 .6rem}

/* image placeholders / hero media (tinted wells) */
.img-placeholder{display:flex;align-items:flex-end;padding:12px;border-radius:var(--radius);background:linear-gradient(135deg,#CBE4DE,#E6D9C0);color:rgba(26,23,18,.5);font-family:var(--font-body);font-size:.7rem;letter-spacing:.02em;min-height:160px}
.hero-media .img-placeholder{aspect-ratio:16/10;min-height:0}
.card-img.img-placeholder{aspect-ratio:3/2;min-height:0;border-radius:var(--radius) var(--radius) 0 0}

/* hero (kept for any page using it) */
.hero{padding:3rem 0 2.5rem;border-bottom:1px solid var(--line-soft)}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;margin:1.25rem 0 0}

/* card grid (magazine: flat, thin border, serif title) */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.75rem}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;text-decoration:none;border-bottom:1px solid var(--line);transition:transform .18s ease,box-shadow .18s ease}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.card .card-body{padding:1.15rem 1.3rem 1.4rem}
.card h3{margin-bottom:.3em}
.card:hover h3{color:var(--accent)}
.card p{font-family:var(--font-body);font-size:.94rem;color:var(--ink-soft);margin-bottom:0}
.card-img{aspect-ratio:3/2;background:var(--paper-2);object-fit:cover;width:100%}

/* breadcrumb */
.breadcrumb{font-family:var(--font-body);font-size:.82rem;color:var(--muted);padding:1rem 0}
.breadcrumb a{color:var(--muted);border:0}
.breadcrumb a:hover{color:var(--accent)}

/* essential details (schema Pattern 9) */
.essential-details{max-width:960px;margin:0 auto;padding:1.25rem 1.5rem 1rem}
.essential-details .ed-label{font-family:var(--font-body);font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin:0 0 .75rem;padding-bottom:.75rem;border-bottom:1px solid var(--line)}
.essential-details .facts-grid{display:grid;grid-template-columns:1fr 1fr;column-gap:3rem;margin:0}
.essential-details .fact{display:flex;justify-content:space-between;padding:.6rem 0;border-bottom:1px solid var(--line-soft)}
.essential-details .fact dt{font-family:var(--font-body);font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:0}
.essential-details .fact dd{font-family:var(--font-body);font-size:.9rem;font-weight:500;color:var(--ink);margin:0;text-align:right}

/* FAQ accordion (JS toggles aria-expanded and sets max-height) */
.faq-item{border-top:1px solid var(--line)}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;font-family:var(--font-display);font-weight:400;font-size:1.2rem;color:var(--ink);padding:1.1rem 2.2rem 1.1rem 0;position:relative}
.faq-q::after{content:"+";position:absolute;right:.2rem;top:1rem;font-family:var(--font-body);font-size:1.5rem;color:var(--accent);line-height:1}
.faq-q[aria-expanded="true"]::after{content:"\2013"}
.faq-a{max-height:0;overflow:hidden;transition:max-height .25s ease}
.faq-a .faq-body{padding:0 0 1.2rem;font-family:var(--font-body);font-size:.97rem;color:var(--ink-soft);line-height:1.6}

/* last reviewed stamp (removed sitewide by Script 3; rule kept harmless) */
.last-reviewed{font-family:var(--font-body);font-size:.82rem;color:var(--muted);font-style:normal;margin-top:1.5rem}

/* email capture (removed sitewide by Script 3; rule kept harmless) */
.capture{background:var(--ink);color:var(--paper);border-radius:var(--radius);padding:2rem 1.75rem;text-align:center}
.capture h2{color:var(--paper)}
.capture p{color:rgba(247,243,236,.85)}
.capture form{display:flex;gap:.6rem;max-width:420px;margin:1rem auto 0;flex-wrap:wrap;justify-content:center}
.capture input[type=email]{flex:1 1 220px;padding:.8rem 1rem;border-radius:var(--radius-sm);border:0;font-size:1rem}
.capture .btn-primary{background:var(--accent)}
.capture .btn-primary:hover{background:var(--accent-deep)}

/* footer (light, matches the magazine homepage) */
.site-footer{background:var(--paper);color:var(--ink-soft);border-top:1.5px solid var(--ink);padding:2.75rem 0 1.75rem;font-family:var(--font-body);font-size:.92rem}
.site-footer a{color:var(--ink);border:0}
.site-footer a:hover{color:var(--accent)}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:2rem;margin-bottom:1.75rem}
.footer-grid h4{font-family:var(--font-body);font-weight:600;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:0 0 .75rem}
.footer-grid ul{list-style:none;padding:0;margin:0}
.footer-grid li{margin-bottom:.5rem}
.footer-legal{border-top:1px solid var(--line-soft);padding-top:1.4rem;font-size:.8rem;color:var(--muted)}

/* scroll reveal */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease}
.reveal.is-visible{opacity:1;transform:none}

.utility-list{padding-left:1.2rem}
.utility-list li{margin-bottom:.5rem}

/* mobile */
@media(max-width:767px){
  body{font-size:16px}
  .nav-toggle{display:block}
  .nav-links{position:fixed;inset:66px 0 auto 0;background:var(--paper);flex-direction:column;gap:0;padding:.5rem 24px 1rem;border-bottom:1.5px solid var(--ink);transform:translateY(-130%);transition:transform .25s ease;box-shadow:var(--shadow-lg)}
  .nav-links.open{transform:translateY(0)}
  .nav-links li{padding:.65rem 0;border-bottom:1px solid var(--line-soft)}
  .essential-details .facts-grid{grid-template-columns:1fr}
  .section{padding:2.5rem 0}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
}
