/* =========================================================
   Filha Boa — Landing Page
   Design direction: "Azulejo" — Modern Portuguese Tile / Civic
   Palette: white + azulejo blue, golden accent, ink-blue text.
   ========================================================= */

/* ---------- Design tokens ---------- */
:root{
  --paper:#FFFFFF; --surface:#EEF4F7; --ink:#15303D; --muted:#577481;
  --primary:#1F5673; --primary-2:#2E6E8E; --primary-ink:#FFFFFF;
  --accent:#D9A441; --deep:#15303D;
  --line:rgba(21,48,61,.12);
  --font-head:"Archivo",system-ui,sans-serif;
  --font-body:"Inter",system-ui,sans-serif;
  --radius:10px; --radius-sm:999px;
  --maxw:1200px; --pad:clamp(20px,5vw,72px);
  --h1:clamp(3rem,9vw,6rem); --h2:clamp(2rem,4.4vw,2.9rem);
}

/* ---------- Reset / base ---------- */
*{box-sizing:border-box;margin:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);color:var(--ink);
  font-family:var(--font-body);font-size:17px;line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--font-head);line-height:1.08;font-weight:800;
  letter-spacing:-.5px;color:var(--ink)}
em{font-style:italic}
.container{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad);width:100%}
.section{padding-block:clamp(56px,9vw,112px)}
[hidden]{display:none!important}
.sr-only,.skip-link{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip-link:focus{position:fixed;top:10px;left:10px;width:auto;height:auto;clip:auto;background:var(--ink);color:#fff;padding:10px 16px;border-radius:8px;z-index:200}

/* ---------- Eyebrow / shared bits ---------- */
.eyebrow{font-family:var(--font-body);font-weight:700;font-size:.8rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--primary);margin-bottom:14px}
.eyebrow--light{color:#fff}
.eyebrow--gold{color:var(--accent)}
.section__head{max-width:680px;margin-bottom:48px}
.section__head h2{font-size:var(--h2)}
.section__head--row{max-width:none;display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap}
.link-arrow{font-weight:700;color:var(--primary);font-size:.98rem;display:inline-block}
.link-arrow span{transition:transform .2s ease;display:inline-block}
.link-arrow:hover span{transform:translateX(5px)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-body);font-weight:700;font-size:1rem;cursor:pointer;border:1.5px solid transparent;
  padding:14px 28px;border-radius:var(--radius-sm);transition:transform .15s ease,background .2s ease,opacity .2s}
.btn:hover{transform:translateY(-2px)}
.btn:focus-visible{outline:3px solid var(--accent);outline-offset:3px}
.btn--lg{padding:17px 34px;font-size:1.05rem}
.btn--sm{padding:10px 20px;font-size:.9rem}
.btn--primary{background:var(--primary);color:var(--primary-ink)}
.btn--primary:hover{background:var(--primary-2)}
.btn--ghost{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.7)}
.btn--ghost:hover{background:rgba(255,255,255,.2)}

/* ---------- Header / nav ---------- */
.site-header{position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--paper) 90%,transparent);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;padding-block:18px}
.brand{font-family:var(--font-head);font-weight:800;font-size:1.5rem;letter-spacing:-.01em}
.brand--light{color:#fff}
.nav__links{display:flex;align-items:center;gap:clamp(18px,2.5vw,36px)}
.nav__links a{font-weight:500;font-size:.98rem}
.nav__links a:not(.btn):hover{color:var(--primary)}
.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav__toggle span{width:24px;height:2px;background:var(--ink);display:block}
.nav__mobile{display:none;flex-direction:column;gap:4px;padding:8px var(--pad) 18px;border-bottom:1px solid var(--line)}
.nav__mobile:not([hidden]){display:flex}
.nav__mobile a{padding:12px 4px;font-weight:600;border-bottom:1px solid var(--line)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:clamp(560px,82vh,820px);display:flex;align-items:flex-end;overflow:hidden}
.hero__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero__overlay{position:absolute;inset:0;
  background:linear-gradient(120deg,rgba(21,48,61,.85) 10%,rgba(21,48,61,.45) 60%,rgba(31,86,115,.5) 100%)}
.hero__inner{position:relative;padding-block:clamp(48px,8vw,96px);max-width:760px}
.hero__title{color:#fff;font-size:var(--h1);margin-bottom:18px}
.hero__sub{color:#eaf1f5;font-size:clamp(1.05rem,2vw,1.3rem);max-width:600px;margin-bottom:32px}
.hero__cta{display:flex;gap:16px;flex-wrap:wrap}

/* ---------- About ---------- */
.about__grid{display:grid;grid-template-columns:1.3fr .9fr;gap:clamp(36px,6vw,80px);align-items:center}
.about__text h2{font-size:var(--h2);margin:6px 0 22px}
.about__text p{color:var(--muted);margin-bottom:18px;max-width:56ch}
.stats{list-style:none;display:grid;gap:16px}
.stat{background:var(--surface);border-radius:var(--radius);padding:24px 28px;display:flex;flex-direction:column;gap:4px;border-left:4px solid var(--primary)}
.stat__num{font-family:var(--font-head);font-weight:800;font-size:2rem;color:var(--deep)}
.stat__label{color:var(--muted);font-size:.95rem}

/* ---------- Mission / accent band ---------- */
.section--accent{background-color:var(--deep);color:#fff;text-align:center;
  background-image:
    linear-gradient(135deg,rgba(217,164,65,.10) 25%,transparent 25%),
    linear-gradient(225deg,rgba(217,164,65,.10) 25%,transparent 25%);
  background-size:34px 34px}
.mission__inner{max-width:880px;margin-inline:auto}
.mission__title{color:#fff;font-size:clamp(1.6rem,3.4vw,2.6rem);margin-bottom:18px}
.mission__sub{color:rgba(255,255,255,.82);font-size:1.15rem;max-width:620px;margin-inline:auto}

/* ---------- Discover / cards ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.card{background:#fff;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);
  border-top:4px solid var(--primary);transition:transform .2s ease,box-shadow .2s ease}
.card:hover{transform:translateY(-6px);box-shadow:0 18px 40px -24px rgba(21,48,61,.45)}
.card__img{aspect-ratio:16/10;object-fit:cover;width:100%}
.card__body{padding:26px 28px 30px}
.card__body h3{font-size:1.4rem;margin-bottom:10px}
.card__body p{color:var(--muted);font-size:1rem;margin-bottom:16px}

/* ---------- Featured story: Presépio ---------- */
.presepio{background:var(--surface)}
.presepio__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,6vw,72px);align-items:center}
.presepio__media img{width:100%;border-radius:var(--radius);aspect-ratio:4/3;object-fit:cover;border:1px solid var(--line)}
.presepio__text h2{font-size:var(--h2);margin:6px 0 18px}
.presepio__text p{color:var(--muted);margin-bottom:22px;max-width:52ch}
.presepio__stats{list-style:none;display:flex;flex-direction:column;gap:10px;margin:0 0 28px}
.presepio__stats li{color:var(--muted);font-size:1rem}
.presepio__stats span{display:inline-block;min-width:2.6ch;font-family:var(--font-head);font-weight:800;
  font-size:1.3rem;color:var(--primary);margin-right:8px}
@media (max-width:880px){
  .presepio__grid{grid-template-columns:1fr}
  .presepio__media{order:-1}
}

/* ---------- Location / map ---------- */
.locmap__grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(32px,6vw,72px);align-items:center}
.locmap__text h2{font-size:var(--h2);margin:6px 0 18px}
.locmap__text p{color:var(--muted);margin-bottom:22px;max-width:50ch}
.locmap__facts{list-style:none;display:flex;flex-direction:column;gap:12px;margin:0 0 28px}
.locmap__facts li{display:flex;align-items:center;gap:12px;color:var(--ink);font-size:1rem}
.locmap__facts i{font-style:normal;font-size:1.15rem;width:1.4em;text-align:center}
.locmap__fig{margin:0}
.locmap__svg{width:100%;height:auto;display:block}
.locmap__cap{font-size:.82rem;color:var(--muted);margin-top:10px;text-align:right}
/* svg map parts */
.m-card{fill:#fff;stroke:var(--line);stroke-width:1}
.m-land{fill:var(--surface)}
.m-coast{fill:none;stroke:var(--primary-2);stroke-width:1.5;opacity:.45}
.m-sealabel{fill:var(--primary-2);font-family:var(--font-body);font-size:14px;font-weight:600;letter-spacing:.12em;text-anchor:middle;opacity:.7}
.m-road{fill:none;stroke:var(--accent);stroke-width:2.5;stroke-dasharray:2 8;stroke-linecap:round}
.m-roadlabel{fill:var(--muted);font-family:var(--font-body);font-size:13px;font-weight:600;text-anchor:middle}
.m-town{fill:var(--ink)}
.m-townlabel{fill:var(--ink);font-family:var(--font-body);font-size:14px;font-weight:500}
.m-townlabel--lg{font-weight:700;text-anchor:middle;font-size:15px}
.m-region{fill:var(--muted);font-family:var(--font-body);font-size:13px;font-weight:500;text-anchor:middle;letter-spacing:.04em}
.m-pin{fill:var(--primary)}
.m-pin-dot{fill:#fff}
.m-pinlabel{fill:var(--ink);font-family:var(--font-head);font-size:17px;font-weight:800;text-anchor:middle}
.m-compass circle{fill:#fff;stroke:var(--line);stroke-width:1}
.m-compass path{fill:var(--primary)}
.m-compass text{fill:var(--muted);font-family:var(--font-body);font-size:12px;font-weight:700;text-anchor:middle}
@media (max-width:880px){
  .locmap__grid{grid-template-columns:1fr}
}

/* ---------- Quote ---------- */
.quote{text-align:center;background:var(--surface)}
.quote__inner{max-width:880px;margin-inline:auto}
.quote__mark{font-family:var(--font-head);font-size:5rem;line-height:.6;color:var(--accent)}
.quote__text{font-family:var(--font-head);font-weight:600;font-size:clamp(1.4rem,3vw,2.1rem);
  line-height:1.3;margin:10px 0 22px;letter-spacing:-.5px}
.quote__by{font-weight:700;color:var(--muted);letter-spacing:.02em}

/* ---------- Gallery ---------- */
.gallery__grid{display:grid;grid-template-columns:2fr 1fr 1fr;grid-auto-rows:220px;gap:18px}
.gallery__grid img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius)}
.gallery__grid img:first-child{grid-row:span 2}

/* ---------- Contact CTA ---------- */
.section--dark{background-color:var(--deep);color:#fff;text-align:center;
  background-image:
    linear-gradient(135deg,rgba(217,164,65,.10) 25%,transparent 25%),
    linear-gradient(225deg,rgba(217,164,65,.10) 25%,transparent 25%);
  background-size:34px 34px}
.cta__inner{max-width:720px;margin-inline:auto}
.cta h2{color:#fff;font-size:var(--h2);margin-bottom:16px}
.cta__sub{color:rgba(255,255,255,.84);font-size:1.15rem;margin-bottom:30px}
.cta__form{display:flex;flex-direction:column;gap:12px;max-width:560px;margin:0 auto 18px;text-align:left}
.cta__row{display:flex;gap:12px;flex-wrap:wrap}
.cta__row .field{flex:1;min-width:200px}
.cta__form input,.cta__form textarea{width:100%;padding:15px 18px;border-radius:var(--radius);
  border:1.5px solid rgba(255,255,255,.35);background:rgba(255,255,255,.08);color:#fff;
  font-family:var(--font-body);font-size:1rem}
.cta__form textarea{resize:vertical;min-height:120px;line-height:1.5}
.cta__form input::placeholder,.cta__form textarea::placeholder{color:rgba(255,255,255,.6)}
.cta__form input:focus,.cta__form textarea:focus{outline:3px solid var(--accent);outline-offset:2px;border-color:transparent}
.cta__form .btn{align-self:flex-start;margin-top:4px}
.hp{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;opacity:0}
.form-status{min-height:1.2em;font-size:.95rem;margin-top:2px}
.form-status.is-ok{color:#bfe8c8}
.form-status.is-err{color:#f6c1b6}
.cta__alt{color:rgba(255,255,255,.7);font-size:.95rem}
.cta__alt a{color:var(--accent);font-weight:600}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:#bcd0da;padding-block:48px}
.footer__top{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.footer__links{display:flex;gap:clamp(16px,2.5vw,32px);flex-wrap:wrap}
.footer__links a{font-weight:500;font-size:.95rem}
.footer__links a:hover{color:#fff}
.footer__rule{border:0;border-top:1px solid rgba(255,255,255,.14);margin:28px 0}
.footer__bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.85rem;color:#7d97a3}

/* ---------- Article (story page) ---------- */
.backbar{border-bottom:1px solid var(--line)}
.backbar .container{display:flex;align-items:center;justify-content:space-between;padding-block:16px}
.backlink{font-weight:600;color:var(--primary);font-size:.95rem}
.backlink:hover{text-decoration:underline}
.article{max-width:780px;margin-inline:auto;padding-block:clamp(36px,6vw,72px)}
.article__eyebrow{color:var(--primary);font-weight:700;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:14px}
.article h1{font-size:clamp(2.1rem,5.4vw,3.3rem);line-height:1.06;margin-bottom:14px}
.article__meta{color:var(--muted);font-size:.95rem;margin-bottom:32px}
.article__fig{margin:0 0 40px}
.article__fig img{width:100%;border-radius:var(--radius);aspect-ratio:16/10;object-fit:cover;border:1px solid var(--line)}
.article__fig figcaption{font-size:.85rem;color:var(--muted);margin-top:10px}
.article__lead{font-size:1.2rem;line-height:1.7;color:var(--ink);margin-bottom:1.2em}
.article__body h2{font-family:var(--font-head);font-size:clamp(1.35rem,3vw,1.8rem);margin:1.8em 0 .5em;color:var(--ink)}
.article__body p{font-size:1.08rem;line-height:1.75;color:#33414a;margin-bottom:1.15em}
.article__credits{margin-top:48px;padding-top:24px;border-top:1px solid var(--line);color:var(--muted);font-size:.95rem;line-height:1.6}
.article__back{margin-top:40px}

/* ---------- Footer bottom link ---------- */
.footer__bottom a{color:inherit;text-decoration:underline;text-underline-offset:2px}
.footer__bottom a:hover{color:#fff}

/* ---------- Responsive ---------- */
@media (max-width:880px){
  .nav__links{display:none}
  .nav__toggle{display:flex}
  .about__grid{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr;gap:22px}
  .gallery__grid{grid-template-columns:1fr 1fr;grid-auto-rows:180px}
  .gallery__grid img:first-child{grid-row:span 1;grid-column:span 2}
}
@media (max-width:520px){
  .hero__cta{flex-direction:column;align-items:stretch}
  .btn{width:100%}
  .footer__bottom{flex-direction:column}
}

/* ---------- Motion / a11y ---------- */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.is-visible{opacity:1;transform:none}
