@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,400;1,9..144,500&family=Manrope:wght@400;500;600;700;800&family=DM+Mono:wght@400;500&family=Sacramento&family=Jost:wght@400;500;600&display=swap');

:root {
  --cream: #FFFFF2;     /* canvas */
  --paper: #FFFFFF;
  --mist:  #EDF4FB;     /* section tint */
  --mist-2:#E3EEF8;     /* deeper tint / footer */
  --blue:  #8CC1ED;     /* brand voltage */
  --blue-deep: #3E86C0; /* hover / small-text accent (contrast-safe) */
  --ink:   #3A3640;     /* soft charcoal, text */
  --ink-2: #2C2932;
  --ink-soft: #6E6873;  /* secondary text */
  --line:  #E9E4DE;
  --line-2:#D9E4EF;

  --r: 20px; --r-sm: 14px;
  --ease: cubic-bezier(0.23, 1, 0.32, 1);
  --shadow: 0 18px 48px -28px rgba(58,54,64,.32);
  --shadow-lg: 0 40px 90px -42px rgba(58,54,64,.4);
  --maxw: 1200px;
  --gut: clamp(20px, 5vw, 40px);
}
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; overflow-x:clip; }
body { font-family:'Manrope',sans-serif; color:var(--ink); background:var(--cream); line-height:1.6; font-size:16px; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow-x:clip; max-width:100%; }
img { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
::selection { background:var(--blue); color:var(--ink-2); }

.serif { font-family:'Fraunces',serif; font-optical-sizing:auto; }
.mono { font-family:'DM Mono',monospace; }
.wrap { max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut); }

.eyebrow { font-family:'DM Mono',monospace; font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--blue-deep); display:inline-flex; align-items:center; gap:10px; }
.eyebrow .idx { color:var(--ink); opacity:.4; }
.eyebrow::after { content:""; width:26px; height:1px; background:var(--line-2); }

/* buttons */
.btn { --pad:15px 28px; display:inline-flex; align-items:center; gap:9px; font-weight:700; font-size:15px; padding:var(--pad); border-radius:100px; cursor:pointer; border:none; white-space:nowrap; transition:transform 180ms var(--ease), background 220ms ease, color 220ms ease, box-shadow 220ms ease, border-color 220ms ease; }
.btn svg { width:17px; height:17px; }
.btn-primary { background:var(--blue); color:var(--ink-2); }
.btn-primary:hover { background:var(--blue-deep); color:#fff; box-shadow:var(--shadow); transform:translateY(-1px); }
.btn-primary:active { transform:scale(.975); }
.btn-ink { background:var(--ink); color:#fff; }
.btn-ink:hover { background:var(--ink-2); transform:translateY(-1px); box-shadow:var(--shadow); }
.btn-ink:active { transform:scale(.975); }
.btn-ghost { background:transparent; color:var(--ink); border:1.5px solid var(--line-2); }
.btn-ghost:hover { border-color:var(--ink); transform:translateY(-1px); }
.btn-ghost:active { transform:scale(.975); }
.btn-light { background:rgba(255,255,255,.14); color:#fff; border:1.5px solid rgba(255,255,255,.6); backdrop-filter:blur(8px); }
.btn-light:hover { background:#fff; color:var(--ink); }
.arrow { transition:transform 220ms var(--ease); }
.btn:hover .arrow { transform:translateX(3px); }

/* NAV */
nav { position:sticky; top:0; z-index:60; background:color-mix(in srgb, var(--cream) 82%, transparent); backdrop-filter:blur(14px) saturate(1.2); border-bottom:1px solid var(--line); }
nav .wrap { display:flex; align-items:center; justify-content:space-between; height:74px; }
.logo { display:flex; align-items:center; }
.logo img { height:26px; width:auto; display:block; }
footer .logo img { height:34px; }
.nav-links { display:flex; gap:34px; font-weight:600; font-size:14.5px; }
.nav-links a { position:relative; color:var(--ink-soft); transition:color 180ms ease; }
.nav-links a::after { content:""; position:absolute; left:0; bottom:-6px; height:2px; width:100%; background:var(--blue); transform:scaleX(0); transform-origin:left; transition:transform 260ms var(--ease); }
.nav-links a:hover, .nav-links a.active { color:var(--ink); } .nav-links a:hover::after, .nav-links a.active::after { transform:scaleX(1); }
.nav-right { display:flex; align-items:center; gap:20px; }
.socials { display:flex; gap:15px; }
.socials a { color:var(--ink-soft); transition:color 180ms ease, transform 180ms var(--ease); }
.socials a:hover { color:var(--blue-deep); transform:translateY(-2px); }
.socials svg { width:18px; height:18px; display:block; }

/* HERO */
.hero { position:relative; min-height:clamp(560px, 90vh, 880px); overflow:hidden; display:flex; align-items:flex-end; }
.hero.short { min-height:clamp(380px, 52vh, 520px); align-items:center; text-align:center; }
.hero img.bg { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center 38%; transform:scale(1.04); animation:heroZoom 14s var(--ease) forwards; }
@keyframes heroZoom { to { transform:scale(1); } }
.hero::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(20,18,24,.5) 0%, rgba(20,18,24,.05) 32%, rgba(20,18,24,.72) 100%); }
.hero.short::after { background:linear-gradient(180deg, rgba(20,18,24,.42), rgba(20,18,24,.52)); }
.hero-content { position:relative; z-index:2; color:#fff; padding-bottom:clamp(40px, 8vh, 84px); max-width:920px; }
.hero.short .hero-content { padding-bottom:0; margin-inline:auto; }
.hero .eyebrow { color:#fff; } .hero .eyebrow .idx{ color:#fff; opacity:.55;} .hero .eyebrow::after{ background:rgba(255,255,255,.4); }
.hero.short .eyebrow { justify-content:center; }
.hero h1 { font-family:'Fraunces',serif; font-weight:500; font-size:clamp(42px, 7vw, 90px); line-height:1.0; letter-spacing:-.02em; margin:18px 0 18px; max-width:16ch; text-shadow:0 6px 40px rgba(0,0,0,.28); }
.hero.short h1 { margin-inline:auto; font-size:clamp(38px,5.4vw,68px); }
.hero h1 em { font-family:'Sacramento',cursive; font-style:normal; font-weight:400; color:var(--blue); font-size:1.18em; line-height:.7; }
.hero p { font-size:clamp(16px,1.6vw,20px); max-width:54ch; color:rgba(255,255,255,.9); }
.hero.short p { margin-inline:auto; }
.hero .cta-row { display:flex; gap:14px; margin-top:34px; flex-wrap:wrap; }
.hero.short .cta-row { justify-content:center; }
.reveal-item { opacity:0; transform:translateY(20px); animation:rise .9s var(--ease) forwards; }
.reveal-item:nth-child(1){animation-delay:.05s}.reveal-item:nth-child(2){animation-delay:.18s}
.reveal-item:nth-child(3){animation-delay:.32s}.reveal-item:nth-child(4){animation-delay:.46s}
@keyframes rise { to { opacity:1; transform:none; } }

/* STATS */
.stats { background:var(--mist); border-block:1px solid var(--line); }
.stats .wrap { display:grid; grid-template-columns:repeat(3,1fr); }
.stat { padding:40px 28px; text-align:center; border-right:1px solid var(--line-2); }
.stat:last-child { border-right:none; }
.stat .n { font-family:'Fraunces',serif; font-weight:500; font-size:clamp(38px,4.6vw,56px); line-height:1; letter-spacing:-.02em; color:var(--ink); }
.stat .l { font-family:'DM Mono',monospace; font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--blue-deep); margin-top:10px; }

/* SECTION SHELL */
section.block { padding-block:clamp(72px, 10vw, 132px); }
.soft { background:var(--mist); }
.sec-head { max-width:680px; margin-bottom:clamp(40px,5vw,64px); }
.sec-head.center { margin-inline:auto; text-align:center; }
.sec-head.center .eyebrow { justify-content:center; }
.sec-head h2 { font-family:'Fraunces',serif; font-weight:500; font-size:clamp(32px,4.4vw,54px); line-height:1.05; letter-spacing:-.02em; margin:18px 0 14px; }
.sec-head p { color:var(--ink-soft); font-size:clamp(16px,1.5vw,18px); max-width:56ch; }
.sec-head.center p { margin-inline:auto; }

/* reveal */
.reveal { opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in { opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s } .reveal[data-d="2"]{ transition-delay:.16s }
.reveal[data-d="3"]{ transition-delay:.24s } .reveal[data-d="4"]{ transition-delay:.32s }

/* MAP */
.map-layout { display:grid; grid-template-columns:1.55fr 1fr; gap:26px; align-items:stretch; }
.map-card { background:var(--paper); border:1px solid var(--line); border-radius:var(--r); padding:24px 22px; display:flex; flex-direction:column; justify-content:flex-start; box-shadow:var(--shadow); }
#worldmap { width:100%; } #worldmap svg { width:100%; height:auto; display:block; }
.country { fill:#E1E9F0; stroke:var(--cream); stroke-width:.5px; transition:fill 240ms var(--ease); }
.country.visited { fill:#C2DFF5; cursor:pointer; }            /* visited = pale blue */
.country.guide { fill:#1F6FB2; cursor:pointer; }              /* guide ready = strong blue, stands out */
@media(hover:hover){ .country.visited:hover { fill:#9CCAEC; } .country.guide:hover { fill:#155A95; } }
.country.active { fill:var(--ink); }

/* reel placeholders (work with me) */
.reel-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; max-width:720px; margin-inline:auto; }
.reel { cursor:pointer; }
.reel-thumb { position:relative; aspect-ratio:9/16; border-radius:var(--r-sm); overflow:hidden; background:linear-gradient(160deg, var(--mist) 0%, var(--mist-2) 100%); display:flex; align-items:center; justify-content:center; border:1px solid var(--line-2); transition:transform 200ms var(--ease), box-shadow 200ms ease; }
@media(hover:hover){ .reel:hover .reel-thumb { transform:translateY(-4px); box-shadow:var(--shadow); } }
.reel .play span { width:54px; height:54px; border-radius:50%; background:#fff; display:flex; align-items:center; justify-content:center; box-shadow:0 8px 24px rgba(0,0,0,.15); transition:transform 160ms var(--ease); }
.reel .play span::before { content:""; border-left:16px solid var(--blue-deep); border-top:10px solid transparent; border-bottom:10px solid transparent; margin-left:4px; }
@media(hover:hover){ .reel:hover .play span { transform:scale(1.1); } }
.reel-tag { position:absolute; top:12px; left:12px; font-family:'DM Mono',monospace; font-size:10px; letter-spacing:.08em; text-transform:uppercase; background:rgba(255,255,255,.88); color:var(--blue-deep); padding:4px 10px; border-radius:100px; }
.reel h3 { font-family:'Fraunces',serif; font-size:17px; font-weight:600; margin:14px 0 4px; letter-spacing:-.01em; }
.reel .views { font-family:'DM Mono',monospace; font-size:11.5px; color:var(--ink-soft); }
@media(max-width:560px){ .reel-grid{ gap:12px; } .reel h3{ font-size:13px; } .reel .views{ font-size:10px; } }

/* spinning globe */
.globe-wrap { position:relative; width:100%; max-width:540px; margin:0 auto; }
.globe-wrap::before { content:""; display:block; padding-top:100%; }  /* robust square (iOS-safe) */
#globe-canvas { position:absolute; inset:0; width:100%; height:100%; display:block; cursor:grab; touch-action:pan-y; }
#globe-canvas:active { cursor:grabbing; }
.globe-label { position:absolute; pointer-events:none; background:var(--ink); color:#fff; font-family:'DM Mono',monospace; font-size:12px; padding:5px 11px; border-radius:100px; transform:translate(-50%,-150%); opacity:0; transition:opacity 150ms ease; white-space:nowrap; z-index:2; }
.globe-label.show { opacity:1; }
.globe-spin { position:absolute; top:6px; right:6px; width:38px; height:38px; border-radius:50%; border:1px solid var(--line-2); background:rgba(255,255,255,.92); color:var(--blue-deep); display:none; align-items:center; justify-content:center; cursor:pointer; z-index:4; box-shadow:var(--shadow); transition:transform 200ms var(--ease), background 180ms ease; -webkit-tap-highlight-color:transparent; backdrop-filter:blur(4px); }
.globe-spin.show { display:flex; animation:fadeIn .25s var(--ease); }
.globe-spin:hover { background:#fff; transform:rotate(35deg); }
.globe-spin:active { transform:scale(.92); }
.globe-spin svg { width:20px; height:20px; }
@keyframes fadeIn { from{ opacity:0; } to{ opacity:1; } }

/* country search */
.map-search { max-width:560px; margin:0 auto clamp(24px,3vw,38px); position:relative; }
.map-search input { width:100%; border:1.5px solid var(--line-2); border-radius:100px; padding:15px 24px; font-size:15px; font-family:'Manrope'; background:var(--paper); transition:border-color 200ms ease; }
.map-search input:focus { outline:none; border-color:var(--blue); }
.search-results { position:absolute; top:calc(100% + 8px); left:0; right:0; background:var(--paper); border:1px solid var(--line); border-radius:18px; box-shadow:var(--shadow-lg); overflow:hidden; max-height:min(60vh,360px); overflow-y:auto; z-index:30; display:none; }
.search-results.show { display:block; }
.sr { display:flex; align-items:center; justify-content:space-between; gap:12px; width:100%; border:none; background:none; padding:12px 20px; font-family:'Manrope'; font-size:15px; cursor:pointer; text-align:left; color:var(--ink); }
.sr:hover { background:var(--mist); }
.sr-sub { color:var(--ink-soft); font-size:13px; }
.sr-empty { padding:14px 20px; color:var(--ink-soft); font-size:14px; }
.sb { font-family:'DM Mono',monospace; font-size:10px; letter-spacing:.06em; text-transform:uppercase; padding:3px 10px; border-radius:100px; white-space:nowrap; }
.sb-guide { background:var(--blue); color:var(--ink-2); }
.sb-photos { background:var(--mist-2); color:var(--blue-deep); }
.sb-soon { background:var(--mist); color:var(--ink-soft); }
.coming-chip { display:flex; align-items:center; justify-content:center; gap:7px; font-family:'DM Mono',monospace; font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--blue-deep); background:var(--mist); border:1px solid var(--line-2); border-radius:100px; padding:11px 14px; text-align:center; cursor:pointer; transition:background 180ms ease, color 180ms ease, border-color 180ms ease; }
a.coming-chip:hover { background:var(--blue); color:var(--ink-2); border-color:var(--blue); }
.coming-chip .arrow { transition:transform 220ms var(--ease); }
a.coming-chip:hover .arrow { transform:translateX(3px); }
.panel .blank-state { text-align:center; padding:14px 6px 6px; }
.panel .blank-emoji { font-size:42px; margin-bottom:12px; }
.panel .blank-state p { color:var(--ink-soft); font-size:15px; margin-bottom:16px; max-width:30ch; margin-inline:auto; }
.panel .blank-link { color:var(--blue-deep); font-weight:700; font-size:14px; }
.map-legend { display:flex; gap:20px; justify-content:center; padding-top:16px; font-family:'DM Mono',monospace; font-size:11px; letter-spacing:.05em; color:var(--ink-soft); text-transform:uppercase; }
.map-legend i { width:10px; height:10px; border-radius:3px; display:inline-block; margin-right:7px; vertical-align:-1px; }
.globe-nav-row { display:flex; align-items:center; justify-content:center; gap:16px; margin-top:14px; }
.panel-nav { display:flex; align-items:center; gap:12px; margin-bottom:20px; padding-bottom:18px; border-bottom:1px solid var(--line); }
.panel-nav .globe-nav-hint { flex:1; text-align:center; }
.panel-nav .globe-nav { width:38px; height:38px; font-size:18px; flex:none; }
.globe-nav { width:42px; height:42px; border-radius:50%; border:1.5px solid var(--line-2); background:var(--paper); color:var(--ink); font-size:20px; line-height:1; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:transform 160ms var(--ease), background 180ms ease, border-color 180ms ease; -webkit-tap-highlight-color:transparent; }
.globe-nav:hover { background:var(--blue); border-color:var(--blue); color:var(--ink-2); transform:translateY(-1px); }
.globe-nav:active { transform:scale(.94); }
.globe-nav-hint { font-family:'DM Mono',monospace; font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-soft); }
.panel { border:1px solid var(--line); border-radius:var(--r); padding:30px; display:flex; flex-direction:column; background:var(--paper); box-shadow:var(--shadow); min-width:0; }
.map-card { min-width:0; }
.panel .flag { font-size:32px; }
.panel h3 { font-family:'Fraunces',serif; font-weight:600; font-size:30px; letter-spacing:-.01em; margin:10px 0 3px; }
.panel .sub { font-family:'DM Mono',monospace; font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--blue-deep); }
.panel .blurb { color:var(--ink-soft); margin:14px 0 18px; font-size:15px; }
/* Panel photo grid, layout adapts to the number of photos (pg-1..pg-4) */
.panel .pgrid { display:grid; gap:8px; margin-bottom:20px; grid-template-columns:minmax(0,1fr) minmax(0,1fr); }
.panel .pgrid img, .panel .pgrid .ph-skel { width:100%; object-fit:cover; border-radius:12px; min-width:0; display:block; }
.panel .pgrid .ph-skel { display:flex; align-items:center; justify-content:center; background:var(--mist-2); font-size:22px; opacity:.5; aspect-ratio:1/1; }
/* 1 photo: one wide image */
.panel .pgrid.pg-1 { grid-template-columns:1fr; }
.panel .pgrid.pg-1 img { aspect-ratio:4/3; }
/* 2 photos: two squares side by side */
.panel .pgrid.pg-2 img { aspect-ratio:1/1; }
/* 3 photos: one tall on the left, two squares stacked on the right */
.panel .pgrid.pg-3 img:not(:first-child) { aspect-ratio:1/1; }
.panel .pgrid.pg-3 img:first-child { grid-row:1/3; grid-column:1; height:100%; }
/* 4 photos: 2x2 squares */
.panel .pgrid.pg-4 img { aspect-ratio:1/1; }
.panel-pop { animation:pop .42s var(--ease); }
@keyframes pop { from{opacity:0; transform:translateY(10px) scale(.99);} to{opacity:1; transform:none;} }

/* PRODUCT CARDS */
.prod-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.prod-grid.two { grid-template-columns:1fr 1fr; gap:26px; max-width:900px; margin-inline:auto; }
.soon-head { text-align:center; font-family:'DM Mono',monospace; font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--blue-deep); margin:clamp(40px,5vw,60px) 0 22px; }
.soon-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:26px; max-width:900px; margin-inline:auto; }
@media(max-width:560px){ .soon-grid{ grid-template-columns:1fr; } .soon-grid .body{ padding:16px 16px 18px; } .soon-grid .prod h3{ font-size:18px; } }
.prod { background:var(--paper); border-radius:var(--r); overflow:hidden; border:1px solid var(--line); transition:transform 260ms var(--ease), box-shadow 260ms ease; display:block; }
@media(hover:hover){ .prod:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); } }
.prod .ph { aspect-ratio:3/4; overflow:hidden; position:relative; background:var(--mist-2); }
.prod .ph img { width:100%; height:100%; object-fit:cover; transition:transform 700ms var(--ease); }
@media(hover:hover){ .prod:hover .ph img { transform:scale(1.05); } }
.prod .body { padding:24px 24px 26px; }
.prod h3 { font-family:'Fraunces',serif; font-size:23px; font-weight:600; letter-spacing:-.01em; margin-bottom:5px; }
.prod .meta { font-family:'DM Mono',monospace; color:var(--ink-soft); font-size:12.5px; margin-bottom:20px; }
.prod .row { display:flex; align-items:center; justify-content:space-between; }
.prod .price { font-family:'Fraunces',serif; font-size:24px; font-weight:600; }
.prod .price small { font-family:'DM Mono',monospace; font-size:12px; color:var(--ink-soft); font-weight:400; }
.price.free { color:var(--blue-deep); }
.ribbon { position:absolute; top:16px; left:16px; font-family:'DM Mono',monospace; font-size:11px; font-weight:500; letter-spacing:.08em; text-transform:uppercase; background:var(--cream); color:var(--ink); padding:6px 12px; border-radius:100px; box-shadow:var(--shadow); }

/* YOUTUBE */
.yt-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:30px; max-width:980px; margin-inline:auto; }
.yt { display:block; }
.yt .thumb { position:relative; aspect-ratio:16/9; border-radius:var(--r-sm); overflow:hidden; box-shadow:var(--shadow); background:var(--mist-2); }
.yt .thumb img { width:100%; height:100%; object-fit:cover; transition:transform 600ms var(--ease); }
@media(hover:hover){ .yt:hover .thumb img { transform:scale(1.05); } }
.yt .thumb::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(20,18,24,.45)); }
.yt .play { position:absolute; z-index:2; inset:0; display:flex; align-items:center; justify-content:center; }
.yt .play span { width:62px; height:62px; border-radius:50%; background:#fff; display:flex; align-items:center; justify-content:center; box-shadow:0 8px 30px rgba(0,0,0,.25); transition:transform 180ms var(--ease); }
.yt .play span::before { content:""; border-left:18px solid #E0322C; border-top:11px solid transparent; border-bottom:11px solid transparent; margin-left:4px; }
@media(hover:hover){ .yt:hover .play span { transform:scale(1.12); } }
.yt .dur { position:absolute; z-index:2; bottom:10px; right:10px; font-family:'DM Mono',monospace; font-size:11px; background:rgba(0,0,0,.7); color:#fff; padding:3px 8px; border-radius:6px; }
.yt h3 { font-family:'Fraunces',serif; font-size:22px; font-weight:600; letter-spacing:-.01em; margin:18px 0 5px; line-height:1.25; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
@media(max-width:920px){ .yt-grid{ grid-template-columns:1fr; } }
.yt .views { font-family:'DM Mono',monospace; font-size:12px; color:var(--ink-soft); }

/* LEAD */
.lead { background:var(--paper); border:1px solid var(--line); border-radius:28px; overflow:hidden; box-shadow:var(--shadow); }
.lead-inner { display:grid; grid-template-columns:1.05fr .95fr; }
.lead .copy { padding:clamp(38px,5vw,60px); }
.lead .copy h2 { font-family:'Fraunces',serif; font-weight:500; font-size:clamp(28px,3.4vw,42px); line-height:1.08; letter-spacing:-.02em; margin:16px 0 14px; }
.lead .copy p { color:var(--ink-soft); font-size:16px; margin-bottom:26px; max-width:42ch; }
.lead form { display:flex; gap:10px; flex-wrap:wrap; }
.lead input { flex:1; min-width:220px; border:1.5px solid var(--line-2); border-radius:100px; padding:15px 22px; font-size:15px; font-family:'Manrope'; transition:border-color 200ms ease; }
.lead input:focus { outline:none; border-color:var(--blue); }
.lead .pic { position:relative; min-height:320px; background:var(--mist-2); } .lead .pic img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.note-mono { font-family:'DM Mono',monospace; font-size:12px; color:var(--ink-soft); margin-top:14px; }

/* WORK WITH ME */
.work { background:var(--mist); border:1px solid var(--line-2); border-radius:28px; overflow:hidden; box-shadow:var(--shadow); }
.work-inner { display:grid; grid-template-columns:1fr 1fr; }
.work .copy { padding:clamp(38px,5vw,60px); }
.work .copy h2 { font-family:'Fraunces',serif; font-weight:500; font-size:clamp(30px,3.6vw,46px); line-height:1.06; letter-spacing:-.02em; margin:16px 0 16px; }
.work .copy p { color:var(--ink-soft); font-size:16px; margin-bottom:24px; max-width:44ch; }
.work .offers { display:flex; flex-wrap:wrap; gap:9px; margin-bottom:28px; }
.work .offers span { font-family:'DM Mono',monospace; font-size:12px; background:#fff; color:var(--blue-deep); border:1px solid var(--line-2); padding:8px 14px; border-radius:100px; }
.work .form-side { background:var(--paper); padding:clamp(32px,4vw,52px); display:flex; flex-direction:column; justify-content:center; border-left:1px solid var(--line-2); }
.work label { font-family:'DM Mono',monospace; font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:7px; display:block; }
.work input, .work textarea { width:100%; border:1.5px solid var(--line-2); border-radius:13px; padding:14px 16px; font-size:15px; font-family:'Manrope'; margin-bottom:18px; background:#fff; color:var(--ink); }
.work input:focus, .work textarea:focus { outline:none; border-color:var(--blue); }
.work textarea { resize:none; }
.work .email-alt { font-family:'DM Mono',monospace; color:var(--ink-soft); font-size:12.5px; margin-top:16px; text-align:center; }
.work .email-alt b { color:var(--blue-deep); font-weight:500; }

/* BLOG */
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.post { background:var(--paper); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; transition:transform 260ms var(--ease), box-shadow 260ms ease; display:block; }
@media(hover:hover){ .post:hover { transform:translateY(-6px); box-shadow:var(--shadow); } }
.post .ph { aspect-ratio:1/1; overflow:hidden; background:var(--mist-2); } .post .ph img { width:100%; height:100%; object-fit:cover; transition:transform 700ms var(--ease); }
@media(hover:hover){ .post:hover .ph img { transform:scale(1.05); } }
.post .body { padding:22px 24px 26px; }
.post .cat { font-family:'DM Mono',monospace; font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--blue-deep); }
.post h3 { font-family:'Fraunces',serif; font-size:19px; font-weight:600; letter-spacing:-.01em; margin:10px 0 7px; line-height:1.3; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.post p { color:var(--ink-soft); font-size:14.5px; }
.post .read { margin-top:14px; font-weight:700; font-size:14px; color:var(--blue-deep); display:inline-flex; gap:6px; }

/* GENERIC PROSE (guide / about) */
.prose { max-width:720px; }
.prose p { color:var(--ink-soft); margin-bottom:18px; font-size:17px; }
.prose h3 { font-family:'Fraunces',serif; font-size:26px; font-weight:600; margin:34px 0 12px; letter-spacing:-.01em; color:var(--ink); }
.prose ul { list-style:none; margin:6px 0 18px; }
.prose li { position:relative; padding-left:22px; margin-bottom:10px; color:var(--ink-soft); }
.prose li::before { content:""; position:absolute; left:0; top:11px; width:7px; height:7px; border-radius:50%; background:var(--blue); }
.gallery { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:14px; }
.gallery img { width:100%; aspect-ratio:3/4; object-fit:cover; border-radius:var(--r-sm); background:var(--mist-2); }
.gallery .skel { aspect-ratio:3/4; border-radius:var(--r-sm); background:var(--mist-2); display:flex; align-items:center; justify-content:center; font-size:26px; opacity:.5; }
.coming { font-family:'DM Mono',monospace; font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); }
.notify-btn { display:inline-flex; align-items:center; justify-content:center; gap:7px; white-space:nowrap; width:100%; max-width:100%; font-weight:700; font-size:13.5px; color:var(--blue-deep); background:var(--mist); border:1px solid var(--line-2); padding:11px 16px; border-radius:100px; cursor:pointer; transition:background 180ms ease, color 180ms ease, border-color 180ms ease, transform 180ms var(--ease); }
.notify-btn:hover { background:var(--blue); color:var(--ink-2); border-color:var(--blue); transform:translateY(-1px); }
.notify-btn .arrow { transition:transform 220ms var(--ease); }
.notify-btn:hover .arrow { transform:translateX(3px); }
.two-col { display:grid; grid-template-columns:1.3fr .7fr; gap:48px; align-items:start; }
.sticky-buy { position:sticky; top:100px; background:var(--paper); border:1px solid var(--line); border-radius:var(--r); padding:28px; box-shadow:var(--shadow); }
.sticky-buy .price { font-family:'Fraunces',serif; font-size:34px; font-weight:600; }
.sticky-buy .price small { font-family:'DM Mono',monospace; font-size:13px; color:var(--ink-soft); }
.sticky-buy ul { list-style:none; margin:18px 0; }
.sticky-buy li { padding-left:24px; position:relative; margin-bottom:10px; font-size:14.5px; color:var(--ink-soft); }
.sticky-buy li::before { content:"✓"; position:absolute; left:0; color:var(--blue-deep); font-weight:700; }

/* ARTICLE */
.article { max-width:760px; margin-inline:auto; }
.article-head { text-align:center; margin-bottom:clamp(26px,4vw,40px); }
.article-head .eyebrow { justify-content:center; }
.article-head h1 { font-family:'Fraunces',serif; font-weight:500; font-size:clamp(32px,5vw,52px); line-height:1.08; letter-spacing:-.02em; margin:14px 0 14px; }
.article-meta { font-family:'DM Mono',monospace; font-size:12px; letter-spacing:.06em; color:var(--ink-soft); text-transform:uppercase; }
.article-hero { display:block; width:100%; height:auto; border-radius:var(--r); margin-bottom:clamp(28px,4vw,44px); background:var(--mist-2); }
.aff-box { background:var(--mist); border:1px solid var(--line-2); border-radius:var(--r); padding:24px 26px; margin:28px 0; }
.aff-box .k { font-family:'DM Mono',monospace; font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--blue-deep); }
.aff-box h4 { font-family:'Fraunces',serif; font-size:21px; font-weight:600; margin:6px 0 8px; }
.aff-box p { color:var(--ink-soft); font-size:14.5px; margin-bottom:16px; }
.code-pill { font-family:'DM Mono',monospace; background:#fff; border:1px dashed var(--line-2); border-radius:8px; padding:4px 10px; color:var(--ink); }

/* LINK-IN-BIO */
.linklist { max-width:600px; margin-inline:auto; display:flex; flex-direction:column; gap:12px; }
.linklist h4 { font-family:'DM Mono',monospace; font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--blue-deep); margin:28px 0 2px; text-align:center; }
.linkbtn { display:flex; align-items:center; justify-content:space-between; gap:14px; background:var(--paper); border:1px solid var(--line); border-radius:100px; padding:17px 26px; font-weight:600; transition:transform 180ms var(--ease), box-shadow 200ms ease, border-color 200ms ease; }
.linkbtn:hover { transform:translateY(-2px); box-shadow:var(--shadow); border-color:var(--blue); }
.linkbtn .code { font-family:'DM Mono',monospace; font-size:11px; color:var(--blue-deep); white-space:nowrap; }
.linkbtn .arrow { color:var(--ink-soft); }

/* FOOTER */
footer { background:var(--mist-2); color:var(--ink); padding:clamp(56px,7vw,80px) 0 32px; border-top:1px solid var(--line-2); }
.foot-signup { display:flex; align-items:center; justify-content:space-between; gap:36px; flex-wrap:wrap; padding-bottom:40px; margin-bottom:40px; border-bottom:1px solid var(--line-2); }
.foot-signup-copy h3 { font-family:'Fraunces',serif; font-size:clamp(22px,3vw,30px); font-weight:600; letter-spacing:-.01em; line-height:1.1; }
.foot-signup-copy p { color:var(--ink-soft); font-size:14.5px; margin-top:8px; max-width:42ch; }
.foot-signup-form { flex:1; min-width:280px; max-width:440px; }
.wl-row { display:flex; gap:10px; }
.wl-row input { flex:1; min-width:0; border:1.5px solid var(--line-2); border-radius:100px; padding:14px 20px; font-size:15px; font-family:'Manrope'; background:var(--paper); transition:border-color 180ms ease; }
.wl-row input:focus { outline:none; border-color:var(--blue); }
.wl-row .btn { white-space:nowrap; }
.foot-signup-form .form-note { margin-top:10px; padding-left:4px; }
@media(max-width:560px){ .wl-row{ flex-direction:column; } .wl-row .btn{ width:100%; justify-content:center; } }
.foot-top { display:flex; justify-content:space-between; gap:48px; flex-wrap:wrap; padding-bottom:40px; border-bottom:1px solid var(--line-2); }
footer .logo { font-size:28px; }
footer .blurb { color:var(--ink-soft); max-width:34ch; margin-top:12px; font-size:14px; }
.foot-cols { display:flex; gap:64px; flex-wrap:wrap; }
.foot-col h4 { font-family:'DM Mono',monospace; font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--blue-deep); margin-bottom:16px; }
.foot-col a { display:block; color:var(--ink-soft); margin-bottom:10px; font-size:14px; transition:color 160ms ease; }
.foot-col a:hover { color:var(--ink); }
.foot-bottom { display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; padding-top:26px; font-family:'DM Mono',monospace; color:var(--ink-soft); font-size:12px; }
.disclosure { max-width:62ch; line-height:1.7; }

@media (max-width:920px){
  .map-layout,.work-inner,.lead-inner,.two-col{ grid-template-columns:1fr; }
  .prod-grid,.blog-grid,.yt-grid{ grid-template-columns:1fr 1fr; }
  .nav-links{ display:none; }
  .sticky-buy{ position:static; }
}
@media (max-width:560px){
  .prod-grid,.prod-grid.two,.blog-grid,.yt-grid,.stats .wrap,.gallery{ grid-template-columns:1fr; }
  .stat{ border-right:none; border-bottom:1px solid var(--line-2); }
}
@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; }
  .reveal{ opacity:1; transform:none; } .hero img.bg{ transform:none; }
}

/* work-with-me form status */
.form-note { margin-top:12px; font-size:14px; min-height:1px; }
.form-note.ok { color:var(--blue-deep); }
.form-note.err { color:#b4413a; }

/* reel videos */
.reel-vid { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; background:#000; z-index:1; }
.reel .play { position:relative; z-index:2; transition:opacity 180ms ease; }
.reel-thumb.playing .play, .reel-thumb.playing .reel-tag { opacity:0; pointer-events:none; }
