/* Seville Fiber — styles
   Aesthetic: country-club heritage meets fiber light.
   Display: Fraunces (serif). Body: Hanken Grotesk. Theme via CSS custom props. */

:root{ --maxw:1120px; }

[data-theme="light"]{
  --bg:#f6f1e6; --bg-soft:#efe7d6; --surface:#fffdf9; --surface-2:#f5efe1;
  --text:#3d4a40; --muted:#6c7a6e; --heading:#16271d;
  --border:#e6ddca; --border-strong:#d6c9ad;
  --accent:#9c6f25; --accent-hover:#825a1a; --accent-bright:#c79a40; --accent-soft:#f2e7c9;
  --green:#173d2b; --green-hover:#1f4f38;
  --good:#2e7d52; --good-soft:#dcefe1;
  --info:#2f6f8f; --info-soft:#dcecf3;
  --warn:#946a1c; --warn-soft:#f1e6c8;
  --idle:#76847a; --idle-soft:#e8ece6;
  --band:#123124; --band-2:#0e2a1f; --band-text:#f4eede; --band-muted:#a8bdaf;
  --shadow:0 14px 44px rgba(20,40,28,.12);
  --header-bg:rgba(246,241,230,.82);
  --tile-ink:rgba(22,39,29,.045);
  --glow-a:rgba(199,154,64,.22); --glow-b:rgba(23,61,43,.10);
}
[data-theme="dark"]{
  --bg:#0f1712; --bg-soft:#131d16; --surface:#17231b; --surface-2:#1c2a21;
  --text:#c2cfc4; --muted:#8a9d8f; --heading:#eef4ea;
  --border:#27352b; --border-strong:#37493c;
  --accent:#d9b059; --accent-hover:#e7c47a; --accent-bright:#e0bd6a; --accent-soft:#2a2516;
  --green:#2c6e4e; --green-hover:#357d5a;
  --good:#4cae7d; --good-soft:#14301f;
  --info:#5aa6c9; --info-soft:#14303b;
  --warn:#d6ad55; --warn-soft:#322a14;
  --idle:#7e9083; --idle-soft:#202a23;
  --band:#0a130e; --band-2:#08110c; --band-text:#eef4ea; --band-muted:#9bb0a2;
  --shadow:0 16px 46px rgba(0,0,0,.45);
  --header-bg:rgba(15,23,18,.82);
  --tile-ink:rgba(216,178,90,.05);
  --glow-a:rgba(216,176,89,.16); --glow-b:rgba(44,110,78,.20);
}

*{box-sizing:border-box; margin:0; padding:0}
html{scroll-behavior:smooth; scroll-padding-top:88px}
body{
  font-family:'Hanken Grotesk',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--bg); color:var(--text); line-height:1.68; font-size:16.5px;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
}

/* subtle azulejo lattice — tiled diamond grid */
.tiled{
  background-image:
    repeating-linear-gradient(45deg, var(--tile-ink) 0 1px, transparent 1px 24px),
    repeating-linear-gradient(-45deg, var(--tile-ink) 0 1px, transparent 1px 24px);
}

.container{max-width:var(--maxw); margin:0 auto; padding:0 24px}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,'Times New Roman',serif; color:var(--heading); line-height:1.12; letter-spacing:-.01em; font-optical-sizing:auto}
a{color:var(--accent); text-decoration:none; transition:color .18s}
a:hover{color:var(--accent-hover)}
section{padding:90px 0; position:relative}

.eyebrow{display:inline-block; color:var(--accent); font-weight:700; font-size:12.5px; letter-spacing:.18em; text-transform:uppercase; margin-bottom:16px}
.section-title{font-size:clamp(1.8rem,3.6vw,2.6rem); font-weight:600; margin-bottom:14px}
.lead{font-size:18.5px; color:var(--muted); max-width:680px}

/* buttons */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:9px; padding:13px 26px; border-radius:11px; font-family:'Hanken Grotesk',sans-serif; font-weight:600; font-size:15.5px; cursor:pointer; border:none; transition:transform .18s ease, box-shadow .18s ease, background .18s, color .18s, border-color .18s; white-space:nowrap}
.btn svg{flex:none}
.btn-primary{background:var(--green); color:#f6f1e6 !important}
.btn-primary:hover{background:var(--green-hover); transform:translateY(-2px); box-shadow:0 10px 26px rgba(23,61,43,.28), 0 0 0 3px var(--accent-soft)}
.btn-ghost{background:var(--surface); color:var(--heading) !important; border:1px solid var(--border-strong)}
.btn-ghost:hover{border-color:var(--accent-bright); color:var(--accent) !important; transform:translateY(-2px)}
.btn-band{background:transparent; color:#fff !important; border:1px solid rgba(255,255,255,.38)}
.btn-band:hover{border-color:var(--accent-bright); background:rgba(255,255,255,.06)}

/* header */
.site-header{position:sticky; top:0; z-index:100; background:var(--header-bg); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); border-bottom:1px solid var(--border)}
.site-header .container{display:flex; align-items:center; justify-content:space-between; height:72px; gap:18px}
.brand{display:flex; align-items:center; gap:12px}
.brand .emblem{width:42px; height:42px; flex:none; filter:drop-shadow(0 3px 8px rgba(20,40,28,.18))}
.brand-text{display:flex; flex-direction:column; line-height:1.12}
.wm{font-family:'Fraunces',serif; font-size:23px; font-weight:600; letter-spacing:-.01em; color:var(--heading)}
.wm b{color:var(--accent-bright); font-weight:600; font-style:italic}
.byline{font-family:'Hanken Grotesk',sans-serif; font-size:10.5px; font-weight:700; color:var(--muted); letter-spacing:.16em; text-transform:uppercase; margin-top:1px}
.nav-links{display:flex; gap:28px; align-items:center}
.nav-links a{color:var(--muted); font-weight:500; font-size:15px; position:relative}
.nav-links a:hover{color:var(--heading)}
.nav-links a.ext::after{content:"↗"; font-size:11px; margin-left:3px; color:var(--accent); vertical-align:top}
.header-actions{display:flex; align-items:center; gap:10px}
.theme-btn,.hamburger{display:inline-flex; align-items:center; justify-content:center; width:42px; height:42px; border-radius:11px; border:1px solid var(--border-strong); background:var(--surface); color:var(--muted); cursor:pointer; transition:color .18s, border-color .18s}
.theme-btn:hover,.hamburger:hover{color:var(--accent); border-color:var(--accent-bright)}
.hamburger{display:none; color:var(--heading)}
[data-theme="light"] .sun{display:none}
[data-theme="dark"] .moon{display:none}
.mobile-nav{display:none}

/* hero */
.hero{text-align:center; padding:96px 0 78px; overflow:hidden;
  background:radial-gradient(1200px 520px at 50% -160px, var(--glow-a), transparent 62%), radial-gradient(900px 440px at 50% 120%, var(--glow-b), transparent 60%)}
.badge{display:inline-flex; align-items:center; gap:9px; padding:7px 17px; border-radius:999px; background:var(--surface); border:1px solid var(--border-strong); color:var(--accent); font-weight:600; font-size:13px; letter-spacing:.02em; margin-bottom:28px; box-shadow:var(--shadow)}
.badge .ping{width:8px; height:8px; border-radius:50%; background:var(--good); box-shadow:0 0 0 0 rgba(46,125,82,.5); animation:ping 2.4s infinite}
@keyframes ping{0%{box-shadow:0 0 0 0 rgba(46,125,82,.45)}70%{box-shadow:0 0 0 9px rgba(46,125,82,0)}100%{box-shadow:0 0 0 0 rgba(46,125,82,0)}}
.hero h1{font-size:clamp(2.5rem,6vw,4.1rem); font-weight:500; max-width:14ch; margin:0 auto 22px; letter-spacing:-.02em}
.hero h1 em{font-style:italic; color:var(--accent-bright)}
.hero .lead{margin:0 auto 16px; font-size:19.5px}
.hero-note{font-size:15px; color:var(--muted); margin:0 auto 36px; max-width:560px}
.hero-note b{color:var(--heading); font-weight:600}
.hero-cta{display:flex; gap:14px; justify-content:center; flex-wrap:wrap}

/* status / phase tracker */
.status-summary{max-width:720px; margin:8px 0 40px}
.track{list-style:none; display:flex; gap:0; counter-reset:step; margin-top:8px}
.track-step{flex:1; display:flex; flex-direction:column; align-items:center; text-align:center; position:relative; padding:0 8px}
.track-step .tdot{width:46px; height:46px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:'Fraunces',serif; font-weight:600; font-size:18px; background:var(--surface); border:2px solid var(--border-strong); color:var(--muted); z-index:2; transition:all .2s}
.track-step .tlabel{margin-top:14px; font-size:14px; font-weight:600; color:var(--muted); max-width:18ch}
.track-step .ttag{margin-top:6px; font-size:11.5px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:transparent}
.track-step:not(:first-child)::before{content:""; position:absolute; top:22px; right:50%; width:100%; height:2px; background:var(--border-strong); z-index:1}
.track-step.is-done .tdot{background:var(--green); border-color:var(--green); color:#f6f1e6}
.track-step.is-done:not(:first-child)::before{background:var(--green)}
.track-step.is-current .tdot{background:var(--accent-bright); border-color:var(--accent-bright); color:var(--band); box-shadow:0 0 0 6px var(--accent-soft)}
.track-step.is-current .tlabel{color:var(--heading)}
.track-step.is-current .ttag{color:var(--accent)}

/* availability */
.avail-intro{max-width:680px; margin-bottom:28px}
.legend{display:flex; flex-wrap:wrap; gap:12px 22px; margin-bottom:30px; padding:18px 22px; background:var(--surface); border:1px solid var(--border); border-radius:14px; box-shadow:var(--shadow)}
.legend-item{display:flex; align-items:center; gap:10px; font-size:14px; color:var(--text)}
.pill{display:inline-flex; align-items:center; gap:7px; font-size:12px; font-weight:700; letter-spacing:.03em; padding:4px 12px; border-radius:999px; white-space:nowrap}
.pill::before{content:""; width:8px; height:8px; border-radius:50%; background:currentColor}
.pill.good{background:var(--good-soft); color:var(--good)}
.pill.info{background:var(--info-soft); color:var(--info)}
.pill.warn{background:var(--warn-soft); color:var(--warn)}
.pill.idle{background:var(--idle-soft); color:var(--idle)}

.empty-state{text-align:center; padding:56px 28px; background:var(--surface); border:1px dashed var(--border-strong); border-radius:16px}
.empty-state .es-emblem{width:54px; height:54px; margin:0 auto 18px; color:var(--accent-bright); opacity:.9}
.empty-state h3{font-size:1.45rem; font-weight:600; margin-bottom:10px}
.empty-state p{color:var(--muted); max-width:460px; margin:0 auto}

/* already-available callout */
.avail-highlight{margin-bottom:22px; padding:26px 28px; background:var(--surface); border:1px solid var(--border); border-left:4px solid var(--good); border-radius:14px; box-shadow:var(--shadow)}
.avail-highlight .ah-head{display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-bottom:10px}
.avail-highlight h3{font-size:1.4rem; font-weight:600}
.avail-highlight p{color:var(--muted)}
.avail-highlight p a{font-weight:600}

.avail-tools{margin-top:6px}
.avail-search{position:relative; max-width:420px; margin-bottom:18px}
.avail-search input{width:100%; padding:13px 16px 13px 44px; border-radius:11px; border:1px solid var(--border-strong); background:var(--surface); color:var(--heading); font-family:inherit; font-size:15px}
.avail-search input:focus{outline:none; border-color:var(--accent-bright); box-shadow:0 0 0 3px var(--accent-soft)}
.avail-search svg{position:absolute; left:15px; top:50%; transform:translateY(-50%); color:var(--muted)}
.avail-table{width:100%; border-collapse:collapse; background:var(--surface); border:1px solid var(--border); border-radius:14px; overflow:hidden; box-shadow:var(--shadow)}
.avail-table thead th{text-align:left; font-size:12px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); padding:14px 18px; border-bottom:1px solid var(--border); background:var(--surface-2)}
.avail-table td{padding:14px 18px; border-bottom:1px solid var(--border); font-size:15px}
.avail-table tbody tr:last-child td{border-bottom:none}
.avail-table td:first-child{font-weight:600; color:var(--heading)}

/* updates timeline */
.timeline{list-style:none; max-width:760px; margin-top:8px; position:relative; padding-left:30px}
.timeline::before{content:""; position:absolute; left:7px; top:8px; bottom:8px; width:2px; background:var(--border-strong)}
.update{position:relative; padding:0 0 34px 0}
.update:last-child{padding-bottom:0}
.update::before{content:""; position:absolute; left:-30px; top:6px; width:16px; height:16px; border-radius:50%; background:var(--accent-bright); border:3px solid var(--bg); box-shadow:0 0 0 2px var(--accent-bright)}
.update time{display:inline-block; font-size:12.5px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--accent); margin-bottom:7px}
.update h3{font-size:1.3rem; font-weight:600; margin-bottom:7px}
.update p{color:var(--muted)}

/* faq */
.faq-list{max-width:820px; margin-top:14px}
details{border-bottom:1px solid var(--border)}
details:first-of-type{border-top:1px solid var(--border)}
summary{cursor:pointer; list-style:none; display:flex; justify-content:space-between; align-items:center; gap:16px; padding:22px 6px; font-family:'Fraunces',serif; font-weight:600; font-size:18px; color:var(--heading)}
summary::-webkit-details-marker{display:none}
summary .mark{flex:none; width:24px; height:24px; position:relative; transition:transform .25s}
summary .mark::before,summary .mark::after{content:""; position:absolute; background:var(--accent); border-radius:2px}
summary .mark::before{top:11px; left:4px; width:16px; height:2px}
summary .mark::after{top:4px; left:11px; width:2px; height:16px; transition:transform .25s}
details[open] summary .mark::after{transform:rotate(90deg)}
details[open] summary .mark{transform:rotate(180deg)}
details p{padding:0 6px 24px; color:var(--muted); max-width:740px}
details p a{font-weight:600}

/* footer band */
footer.band{background:var(--band); color:var(--band-muted); padding:60px 0 0; position:relative; overflow:hidden}
footer.band .container{position:relative; z-index:1}
.foot-grid{display:flex; justify-content:space-between; gap:48px; flex-wrap:wrap; padding-bottom:34px}
.foot-brand{max-width:380px}
.foot-brand .brand .wm{color:#fff}
.foot-brand .brand .emblem{filter:drop-shadow(0 3px 8px rgba(0,0,0,.4))}
.foot-tagline{font-size:14.5px; margin-top:14px; color:var(--band-muted)}
.foot-col h4{font-family:'Hanken Grotesk',sans-serif; color:#fff; font-size:13px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; margin-bottom:15px}
.foot-col a{display:block; color:var(--band-muted); font-size:14.5px; margin-bottom:10px}
.foot-col a:hover{color:var(--accent-bright)}
.disclaimer{border-top:1px solid rgba(255,255,255,.12); padding:24px 0; font-size:13px; line-height:1.6; color:var(--band-muted); max-width:880px}
.disclaimer b{color:#fff; font-weight:600}
.disclaimer a{color:var(--accent-bright); font-weight:600}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12); padding:18px 0 26px; font-size:13px; display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap; color:var(--band-muted)}

/* 404 */
.notfound{min-height:62vh; display:flex; align-items:center; text-align:center;
  background:radial-gradient(1100px 480px at 50% -140px, var(--glow-a), transparent 62%)}
.notfound .code{font-family:'Fraunces',serif; font-size:clamp(4.5rem,12vw,8rem); font-weight:600; color:var(--accent-bright); line-height:1}
.notfound h1{font-size:clamp(1.6rem,3.2vw,2.3rem); font-weight:600; margin:6px 0 14px}
.notfound .lead{margin:0 auto 30px}
.notfound .hero-cta{display:flex; gap:14px; justify-content:center; flex-wrap:wrap}

/* reveal */
html.js .reveal{opacity:0; transform:translateY(28px); transition:opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1)}
html.js .reveal.in{opacity:1; transform:none}
@media (prefers-reduced-motion: reduce){
  html.js .reveal{opacity:1; transform:none; transition:none}
  .badge .ping{animation:none}
  html{scroll-behavior:auto}
}

@media (max-width:980px){
  .nav-links{display:none}
  .hamburger{display:inline-flex}
  .mobile-nav{display:none; flex-direction:column; gap:2px; padding:8px 24px 18px; border-top:1px solid var(--border); background:var(--header-bg); backdrop-filter:blur(14px)}
  .mobile-nav.open{display:flex}
  .mobile-nav a{padding:12px 0; color:var(--heading); font-weight:600; font-size:16px}
  .track{flex-wrap:wrap; gap:22px 0}
  .track-step{flex:0 0 50%}
  .track-step:not(:first-child)::before{display:none}
  .track-step.is-current .tdot{box-shadow:0 0 0 5px var(--accent-soft)}
}
@media (max-width:620px){
  section{padding:64px 0}
  .foot-grid{gap:32px}
  .foot-bottom{flex-direction:column; gap:6px}
  .track-step{flex:0 0 100%}
  .legend{gap:12px 16px}
}
