/* MiamiSway design system — bold/magazine, pastel Miami palette. Hand-written, no build. */
:root{
  --ink:#1b2440; --ink2:#2a3760; --cream:#fff8f0; --paper:#fdf6ee;
  --coral:#f4a18b; --sun:#f6cf9a; --magenta:#e08cad; --aqua:#8fd4cc; --blue:#9bb1e2; --gold:#ecca8c;
  --accent:#b5547e; --line:rgba(27,36,64,.12); --mut:#6a7186; --body:#39415a;
  --sans:"Space Grotesk",system-ui,sans-serif;
  --serif:"Newsreader",Georgia,serif;
  --disp:"Fraunces",Georgia,serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--serif);font-size:19px;line-height:1.62;-webkit-font-smoothing:antialiased}
a{color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.eyebrow{font-family:var(--sans);text-transform:uppercase;letter-spacing:.14em;font-size:12px;font-weight:600}
.disp{font-family:var(--disp);font-weight:600;line-height:1.0;letter-spacing:-.02em}

/* header */
.site{position:sticky;top:0;z-index:40;background:rgba(20,26,48,.94);backdrop-filter:blur(8px);color:var(--cream)}
.site .bar{display:flex;align-items:center;gap:20px;height:62px}
.brand{font-family:var(--disp);font-weight:600;font-size:23px;letter-spacing:-.03em;text-decoration:none;color:var(--cream)}
.brand b{color:var(--magenta)}
.nav{display:flex;gap:15px;font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.02em;flex-wrap:wrap}
.nav a{color:var(--cream);opacity:.82;text-decoration:none;padding:4px 0;border-bottom:2px solid transparent}
.nav a:hover,.nav a.on{opacity:1;border-color:var(--aqua)}
.langtoggle{margin-left:auto;display:flex;gap:2px;font-family:var(--sans);font-size:12px;font-weight:600}
.langtoggle a{color:rgba(255,248,240,.6);text-decoration:none;padding:4px 8px;border-radius:7px;letter-spacing:.04em}
.langtoggle a.on{color:var(--ink);background:var(--gold)}
.langtoggle a:hover{color:var(--cream)}
.site form.search{margin-left:14px}
.site form.search input{font-family:var(--sans);font-size:13px;color:var(--cream);background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:9px 16px;width:170px}
.site form.search input::placeholder{color:rgba(255,248,240,.6)}

/* hero images: cover their box (cards + entity hero) */
.ph{background-size:cover;background-position:center;background-repeat:no-repeat}
/* gradient placeholders (until hero_image is set) */
.img{position:relative;overflow:hidden;background:var(--ink2)}
.g-sunset{background:radial-gradient(120% 120% at 15% 10%,var(--gold),var(--sun) 32%,var(--coral) 55%,var(--magenta) 88%)}
.g-ocean{background:linear-gradient(150deg,var(--aqua),var(--blue) 60%,var(--ink) 100%)}
.g-neon{background:linear-gradient(135deg,var(--magenta),var(--coral) 45%,var(--aqua) 100%)}
.g-deco{background:linear-gradient(160deg,#fbe0c2,var(--coral) 55%,var(--ink2))}
.g-violet{background:linear-gradient(145deg,#b3a3e6,var(--magenta) 70%,var(--coral))}
.g-lime{background:linear-gradient(150deg,#c2e0a2,var(--aqua) 60%,var(--blue))}
.sun{position:absolute;width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,.5);right:-22px;top:-22px;mix-blend-mode:soft-light}

/* hero (homepage) */
.hero{background:var(--ink);color:var(--cream);position:relative;overflow:hidden}
.hero .heroimg{position:absolute;inset:0}
.hero .heroinner{position:relative;padding:92px 0 80px}
.hero .kick{color:var(--gold)}
.hero h1{font-family:var(--disp);font-weight:600;font-size:clamp(46px,8vw,100px);line-height:.92;letter-spacing:-.03em;margin:14px 0 18px;max-width:14ch;text-shadow:0 2px 30px rgba(0,0,0,.35)}
.hero h1 em{font-style:italic;color:var(--aqua)}
.hero .lede{font-size:23px;max-width:46ch;color:rgba(255,248,240,.92)}
.hero form{margin-top:28px;display:flex;gap:10px;max-width:520px}
.hero form input{flex:1;font-family:var(--sans);font-size:16px;padding:15px 18px;border-radius:999px;border:0;background:rgba(255,255,255,.96);color:var(--ink)}
.btn{font-family:var(--sans);font-weight:600;font-size:15px;border:0;border-radius:999px;padding:15px 22px;background:var(--accent);color:#fff;cursor:pointer;text-decoration:none}

/* section heading on light */
.sechead{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin:60px 0 24px}
.sechead h2{font-family:var(--disp);font-weight:600;font-size:clamp(28px,4vw,44px);letter-spacing:-.02em;margin:6px 0 0}
.sechead .eyebrow{color:var(--accent)}
.seelink{font-family:var(--sans);font-size:13px;font-weight:500;text-decoration:none;border:1px solid var(--line);border-radius:999px;padding:7px 15px;color:var(--ink)}

/* pillars */
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.pill{position:relative;border-radius:18px;padding:20px 18px;color:var(--ink);min-height:124px;display:flex;flex-direction:column;justify-content:space-between;text-decoration:none;overflow:hidden;transition:transform .15s ease}
.pill .n{font-family:var(--disp);font-weight:600;font-size:38px;line-height:1}
.pill .l{font-family:var(--sans);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:13px}
.pill:hover{transform:translateY(-3px)}

/* cards */
.feat,.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:var(--paper);border-radius:18px;overflow:hidden;border:1px solid var(--line);text-decoration:none;color:var(--ink);display:flex;flex-direction:column;transition:.16s ease}
.card:hover{box-shadow:0 14px 38px rgba(27,36,64,.13);transform:translateY(-3px)}
.card .ph{height:184px;position:relative}
.card .body{padding:18px 20px 22px}
.card .ek{font-family:var(--sans);font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:11px;color:var(--accent)}
.card h3{font-family:var(--disp);font-weight:600;font-size:26px;line-height:1.05;letter-spacing:-.02em;margin:7px 0 9px}
.card p{margin:0;color:var(--body);font-size:16px;line-height:1.5}
.feat.big .card:first-child{grid-column:span 3;flex-direction:row}
.feat.big .card:first-child .ph{width:46%;min-height:300px}
.feat.big .card:first-child .body{padding:34px 36px;align-self:center}
.feat.big .card:first-child h3{font-size:42px}
.feat.big .card:first-child p{font-size:18px}

/* timeline */
.timeline{display:flex;gap:12px;overflow-x:auto;padding:6px 2px 16px}
.tnode{flex:0 0 auto;width:160px;border-radius:14px;border:1px solid var(--line);padding:14px;background:#fff;text-decoration:none;color:var(--ink)}
.tnode .yr{font-family:var(--sans);font-weight:700;font-size:12px;color:var(--blue);letter-spacing:.04em}
.tnode .tt{font-family:var(--disp);font-weight:600;font-size:18px;line-height:1.05;margin-top:6px}
.tnode:hover{border-color:var(--accent)}

/* thesis band */
.bigband{background:var(--ink);color:var(--cream);margin-top:66px}
.bigband .inner{padding:58px 0}
.bigband h2{font-family:var(--disp);font-weight:600;font-size:clamp(28px,5vw,56px);letter-spacing:-.02em;max-width:20ch;line-height:1.04;margin:10px 0 0}
.bigband h2 em{font-style:italic;color:var(--aqua)}

/* section index band */
.indexband{padding:50px 0 24px;border-bottom:1px solid var(--line)}
.indexband .eyebrow{color:var(--accent)}
.indexband h1{font-family:var(--disp);font-weight:600;font-size:clamp(38px,6vw,70px);letter-spacing:-.03em;margin:8px 0 12px}
.indexband p{max-width:62ch;color:var(--body);margin:0;font-size:19px}
.grid{margin:30px 0}

/* entity */
.entry{max-width:1080px;margin:0 auto}
.crumb{font-family:var(--sans);font-size:13px;color:var(--mut);padding:18px 0 0}
.crumb a{text-decoration:none;color:var(--mut)}.crumb a:hover{color:var(--accent)}
.ehero{position:relative;border-radius:22px;overflow:hidden;margin:14px 0 0;color:#fff}
.ehero .ph{position:absolute;inset:0}
.ehero .scrim{position:absolute;inset:0;background:linear-gradient(0deg,rgba(15,19,36,.86),rgba(15,19,36,.15) 60%,rgba(15,19,36,.4))}
.ehero .ei{position:relative;padding:150px 40px 30px}
.ehero .ek{color:var(--gold)}
.ehero h1{font-family:var(--disp);font-weight:600;font-size:clamp(40px,6vw,74px);letter-spacing:-.03em;margin:10px 0 12px;text-shadow:0 2px 24px rgba(0,0,0,.45)}
.ehero .lede{font-style:italic;font-size:22px;max-width:60ch;color:rgba(255,255,255,.95)}

/* article body: prose + At-a-glance sidebar */
.entrygrid{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:46px;margin-top:26px;align-items:start}
.aside{position:sticky;top:84px}
.agcard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px 22px;box-shadow:0 8px 26px rgba(27,36,64,.06)}
.agtitle{font-family:var(--sans);font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:12px;color:var(--accent);padding-bottom:12px;margin-bottom:6px;border-bottom:2px solid var(--gold)}
.agcard ul{list-style:none;margin:0;padding:0}
.agcard li{font-family:var(--serif);font-size:15.5px;line-height:1.45;padding:10px 0;border-bottom:1px solid var(--line)}
.agcard li:last-child{border-bottom:0;padding-bottom:0}
.agcard li strong{font-family:var(--sans);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--mut);display:block;margin-bottom:2px}
.agcard a[href^="/"]{color:var(--accent);text-decoration:none;border-bottom:1px solid rgba(181,84,126,.32)}
.agcard a[href^="/"]:hover{background:#fbeaf1}
.agcard p{margin:0 0 8px;font-size:15.5px}
.prose{font-size:19px}
.prose h2{font-family:var(--disp);font-weight:600;font-size:30px;letter-spacing:-.01em;margin:36px 0 12px;padding-bottom:8px;border-bottom:2px solid var(--gold);display:inline-block}
.prose p{margin:0 0 18px}
.prose ul{margin:0 0 20px;padding-left:0;list-style:none}
.prose ul li{padding:6px 0;border-bottom:1px solid var(--line);font-size:17px}
.prose a[href^="/"]{color:var(--accent);text-decoration:none;border-bottom:1px solid rgba(181,84,126,.32);font-weight:500}
.prose a[href^="/"]:hover{background:#fbeaf1;border-color:var(--accent)}
.prose a[href^="http"]{color:var(--accent);text-decoration:none;border-bottom:1px solid rgba(181,84,126,.3)}
.prose hr{border:0;border-top:1px solid var(--line);margin:30px 0}
.prose strong{font-weight:600}
.draft{font-family:var(--sans);font-size:12px;color:#9a7b2f;background:#fbf2dd;border:1px solid #ecd9a6;border-radius:999px;padding:4px 12px;display:inline-block;margin:8px 0 0}
/* static pages */
.staticpage{max-width:760px;padding-top:24px}
.prose h1{font-family:var(--disp);font-weight:600;font-size:clamp(32px,5vw,52px);letter-spacing:-.02em;margin:6px 0 18px;line-height:1.04}
.contactform{display:flex;flex-direction:column;gap:16px;margin:26px 0 0;max-width:580px}
.contactform label{display:flex;flex-direction:column;gap:6px;width:100%}
.contactform label span{font-family:var(--sans);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--mut)}
.contactform input,.contactform textarea{display:block;width:100%;box-sizing:border-box;font-family:var(--serif);font-size:17px;padding:12px 14px;border:1px solid var(--line);border-radius:12px;background:#fff;color:var(--ink)}
.contactform textarea{resize:vertical;min-height:140px}
.contactform input:focus,.contactform textarea:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px rgba(181,84,126,.12)}
.contactform .btn{align-self:flex-start}
.contactform .hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.formok{font-family:var(--sans);background:#e9f7f2;border:1px solid #9fd9c9;color:#1f6f5a;border-radius:12px;padding:14px 18px;margin:22px 0 0}
.formerr{font-family:var(--sans);background:#fdeceb;border:1px solid #f0b3ad;color:#a23a31;border-radius:12px;padding:12px 16px;margin:22px 0 12px}

/* connected (relationships graph) */
.connected{margin:48px 0 0;padding-top:26px;border-top:2px solid var(--gold)}
.conhead{color:var(--accent);margin-bottom:14px}
.congroup{display:grid;grid-template-columns:150px 1fr;gap:14px;padding:12px 0;border-bottom:1px solid var(--line);align-items:baseline}
.conlabel{font-family:var(--sans);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--mut)}
.conchips{display:flex;flex-wrap:wrap;gap:8px}
.conchip{font-family:var(--sans);font-size:13.5px;text-decoration:none;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:999px;padding:6px 13px;transition:.14s ease}
.conchip:hover{border-color:var(--accent);color:var(--accent);background:#fbeaf1}
.conmore{font-family:var(--sans);font-size:12.5px;color:var(--mut);align-self:center;padding:6px 4px}

.prevnext{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:46px 0 0}
.pn{border:1px solid var(--line);border-radius:14px;padding:15px 18px;text-decoration:none;color:var(--ink);font-family:var(--sans)}
.pn:hover{border-color:var(--accent)}
.pn .d{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--mut)}
.pn .t{font-family:var(--disp);font-size:21px;margin-top:4px}
.pn.next{text-align:right}

/* footer */
footer.site-f{background:var(--ink);color:rgba(255,248,240,.8);padding:48px 0 60px;font-family:var(--sans);font-size:14px;margin-top:70px}
footer.site-f .cols{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:24px}
footer.site-f a{color:rgba(255,248,240,.8);text-decoration:none;display:block;padding:4px 0}
footer.site-f a:hover{color:var(--aqua)}
footer.site-f .fb{font-family:var(--disp);font-size:25px;color:var(--cream)}
footer.site-f h5{font-family:var(--sans);text-transform:uppercase;letter-spacing:.1em;font-size:12px;color:var(--gold);margin:0 0 6px}

@media(max-width:900px){
  .pillars{grid-template-columns:repeat(2,1fr)}
  .feat,.grid{grid-template-columns:1fr 1fr}
  .feat.big .card:first-child{flex-direction:column}
  .feat.big .card:first-child .ph{width:100%;min-height:200px}
  .nav{display:none}
  footer.site-f .cols{grid-template-columns:1fr 1fr}
  .ehero .ei{padding:110px 22px 24px}
  .entrygrid{grid-template-columns:1fr;gap:26px}
  .aside{position:static}
  .aside{order:-1}
}
