:root{
  --bg0:#04080c;
  --bg1:#050b10;
  --bg2:#07121a;
  --card:rgba(255,255,255,.05);
  --card2:rgba(255,255,255,.07);
  --stroke:rgba(255,255,255,.11);
  --text:#ecf7ff;
  --muted:rgba(236,247,255,.72);
  --muted2:rgba(236,247,255,.56);
  --shadow: 0 18px 60px rgba(0,0,0,.62);
  --shadow2: 0 12px 36px rgba(0,0,0,.42);
  --r:18px;
  --r2:28px;
  --c-cyan:#22d3ee;
  --c-green:#34d399;
  --c-orange:#fb923c;
  --c-blue:#60a5fa;
  --focus: 0 0 0 4px rgba(34,211,238,.22);
}

*{box-sizing:border-box}
html{
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}
html,body{height:100%}
body{
  margin:0;
  padding-left:max(0px, env(safe-area-inset-left, 0px));
  padding-right:max(0px, env(safe-area-inset-right, 0px));
  padding-bottom:max(0px, env(safe-area-inset-bottom, 0px));
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  background:
    radial-gradient(900px 650px at 15% -10%, rgba(34,211,238,.18), transparent 60%),
    radial-gradient(900px 650px at 90% 10%, rgba(96,165,250,.14), transparent 55%),
    radial-gradient(980px 650px at 70% 95%, rgba(251,146,60,.12), transparent 55%),
    linear-gradient(180deg, var(--bg0), var(--bg1));
  overflow-x:hidden;
}

/* Gallery map doodle background */
body:before{
  content:"";
  position:fixed; inset:0;
  pointer-events:none;
  opacity:.14;
  background-image:
    radial-gradient(circle at 12% 18%, rgba(255,255,255,.12) 1px, transparent 2px),
    radial-gradient(circle at 68% 28%, rgba(255,255,255,.10) 1px, transparent 2px),
    radial-gradient(circle at 44% 74%, rgba(255,255,255,.10) 1px, transparent 2px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 320px 320px, 380px 380px, 420px 420px, 64px 64px, 64px 64px;
  background-position: 0 0, 120px 60px, 40px 80px, 0 0, 0 0;
  mix-blend-mode: screen;
  filter: blur(.15px);
}

a{color:inherit}
a:hover{color:#fff}

.skip-link{
  position:absolute;
  left:-999px; top:12px;
  padding:10px 12px;
  background:rgba(0,0,0,.85);
  border:1px solid var(--stroke);
  border-radius:12px;
  z-index:9999;
}
.skip-link:focus{left:12px; outline:none; box-shadow:var(--focus)}

.container{width:min(1140px, calc(100% - clamp(16px, 5.5vw, 40px))); margin:0 auto; max-width:100%}
main{display:block; max-width:100%; overflow-x:clip}
.muted{color:var(--muted)}
.tiny{font-size:12.5px; line-height:1.5; color:var(--muted2)}
.lead{font-size:18px; line-height:1.6}

h1,h2,h3{
  font-family: Fraunces, ui-serif, Georgia, serif;
  margin:0 0 10px;
  letter-spacing:-.01em;
}
h1{font-size: clamp(26px, 6.5vw, 60px); line-height:1.1; overflow-wrap: anywhere; word-wrap: break-word; hyphens: auto; -webkit-hyphens: auto}
h2{font-size: clamp(24px, 2.8vw, 38px); line-height:1.12}
h3{font-size:18px; line-height:1.2; font-family: Inter, system-ui}

.grad{
  background: linear-gradient(90deg, var(--c-cyan), var(--c-blue) 42%, var(--c-green) 74%, var(--c-orange));
  -webkit-background-clip:text; background-clip:text;
  color:transparent;
}

.pill{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 12px;
  border:1px solid var(--stroke);
  border-radius:999px;
  background: rgba(255,255,255,.03);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
  color:var(--muted);
  font-size:12.5px;
  max-width:100%;
  flex-wrap:wrap;
}
@media (max-width: 480px){
  .pill{font-size:11.5px; padding:7px 10px; line-height:1.35}
}
.pill .dot{
  width:8px; height:8px; border-radius:999px;
  background: radial-gradient(circle at 40% 35%, #fff, var(--c-cyan));
  box-shadow: 0 0 0 4px rgba(34,211,238,.14), 0 0 14px rgba(34,211,238,.45);
}

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:12px 16px;
  border-radius:14px;
  border:1px solid var(--stroke);
  background:rgba(255,255,255,.04);
  color:var(--text);
  text-decoration:none;
  cursor:pointer;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
  transition: transform .15s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.btn:hover{transform: translateY(-1px); background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.18)}
.btn:active{transform: translateY(0)}
.btn:focus-visible{outline:2px solid rgba(34,211,238,.45); outline-offset:2px; box-shadow: var(--focus), inset 0 1px 0 rgba(255,255,255,.08)}
.nav-link:focus-visible{outline:2px solid rgba(34,211,238,.5); outline-offset:2px; box-shadow:var(--focus)}
.chip:focus-visible{outline:2px solid rgba(34,211,238,.5); outline-offset:2px; box-shadow:var(--focus)}
.btn-primary{
  border-color: rgba(34,211,238,.35);
  background: linear-gradient(135deg, rgba(34,211,238,.18), rgba(96,165,250,.16));
  box-shadow: 0 16px 50px rgba(34,211,238,.08), inset 0 1px 0 rgba(255,255,255,.10);
}
.btn-ghost{background:rgba(255,255,255,.02)}
.btn-block{width:100%}

.site-header{
  position:sticky;
  top:max(14px, env(safe-area-inset-top, 0px));
  z-index:50;
  margin:max(6px, env(safe-area-inset-top, 0px)) auto 0;
  width:min(1180px, calc(100% - clamp(16px, 4vw, 32px)));
  max-width:100%;
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(6,12,16,.56);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: var(--shadow2);
}
.nav-shell{display:flex; align-items:center; justify-content:space-between; gap:10px; padding:10px 12px; min-width:0}
.brand{display:flex; align-items:center; gap:8px; text-decoration:none; min-width:0; flex:1 1 auto}
.brand-mark{
  width:30px; height:30px; border-radius:12px;
  background:
    radial-gradient(circle at 35% 30%, rgba(255,255,255,.9), rgba(255,255,255,0) 45%),
    radial-gradient(circle at 40% 35%, rgba(34,211,238,.95), rgba(34,211,238,0) 60%),
    radial-gradient(circle at 65% 60%, rgba(251,146,60,.75), rgba(251,146,60,0) 60%),
    rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.16);
  box-shadow: 0 10px 26px rgba(0,0,0,.35);
}
.brand-name{font-weight:800; letter-spacing:-.02em; font-family: Inter; font-size: clamp(14px, 3.5vw, 16px); white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.nav{display:flex; gap:10px; align-items:center}
.nav-link{
  padding:10px 12px; text-decoration:none;
  border-radius:12px;
  color:var(--muted);
  border:1px solid transparent;
  transition: background .2s ease, border-color .2s ease, color .2s ease;
}
.nav-link:hover{color:var(--text); background:rgba(255,255,255,.03); border-color:rgba(255,255,255,.10)}
.nav-link.is-active{color:var(--text); background:rgba(34,211,238,.08); border-color:rgba(34,211,238,.22)}
.nav-actions{display:flex; gap:8px; align-items:center; flex-shrink:0}
.nav-toggle{display:none}
.nav-mobile{
  padding:10px 12px 12px;
  border-top:1px solid rgba(255,255,255,.10);
  display:grid;
  gap:8px;
}
.nav-mobile-cta{
  display:grid;
  gap:10px;
  margin-bottom:4px;
  padding-bottom:12px;
  border-bottom:1px solid rgba(255,255,255,.10);
}
.nav-mobile[hidden]{display:none !important}
.nav-mobile .nav-link{
  min-height:44px;
  display:flex;
  align-items:center;
}

.section{padding: 54px 0}
.section-soft{background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0))}
.section-head{display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:18px}
.cta-row{display:flex; gap:12px; flex-wrap:wrap; margin:18px 0 10px}

.card{
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  border-radius: var(--r);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
  padding:16px;
}

.hero{
  padding: 44px 0 10px;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:26px;
  align-items:center;
  min-width:0;
}
.hero-grid > *{ min-width:0 }
.hero-art{
  border-radius: var(--r2);
  max-width:100%;
  border:1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(900px 520px at 20% 10%, rgba(34,211,238,.14), transparent 55%),
    radial-gradient(850px 520px at 90% 20%, rgba(96,165,250,.12), transparent 55%),
    radial-gradient(900px 520px at 80% 88%, rgba(251,146,60,.10), transparent 55%),
    rgba(255,255,255,.02);
  box-shadow: var(--shadow);
  overflow:hidden;
  position:relative;
  min-height: 440px;
}
.hero-canvas{position:absolute; inset:0; width:100%; height:100%; max-width:100%; display:block; box-sizing:border-box}
.hero-overlay{
  position:absolute; inset:0;
  background:
    radial-gradient(900px 520px at 50% 30%, rgba(255,255,255,.06), transparent 65%),
    linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.35));
  pointer-events:none;
}
.hero-caption{margin-top:10px}

.chips{display:flex; flex-wrap:wrap; gap:10px; margin: 10px 0 16px}
.chip{
  padding:10px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  color: rgba(236,247,255,.88);
  cursor:pointer;
  transition: background .2s ease, border-color .2s ease, transform .15s ease;
  user-select:none;
}
.chip:hover{background: rgba(255,255,255,.05); border-color: rgba(255,255,255,.18); transform: translateY(-1px)}
.chip.is-active{background: rgba(34,211,238,.10); border-color: rgba(34,211,238,.24)}

.grid{display:grid; gap:14px}
.form-grid-2{grid-template-columns: repeat(2, minmax(0,1fr))}
.form-grid-3{grid-template-columns: repeat(3, minmax(0,1fr))}
.grid-2{grid-template-columns: repeat(2, minmax(0,1fr))}
.grid-3{grid-template-columns: repeat(3, 1fr)}
.grid-4{grid-template-columns: repeat(4, 1fr)}

.route-card{
  padding:14px;
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
  transition: transform .15s ease, border-color .2s ease, background .2s ease;
  position:relative;
  overflow:hidden;
}
.route-card:hover{transform: translateY(-2px); border-color: rgba(255,255,255,.18); background: rgba(255,255,255,.05)}
.route-card:focus-within{box-shadow: var(--focus), inset 0 1px 0 rgba(255,255,255,.06)}
.route-top{display:flex; align-items:flex-start; justify-content:space-between; gap:12px}
.route-title{font-weight:900}
.route-meta{display:flex; gap:10px; flex-wrap:wrap; margin-top:8px; color:rgba(236,247,255,.82); font-size:13px}
.route-badge{padding:6px 10px; border-radius:999px; border:1px solid rgba(255,255,255,.12); background: rgba(0,0,0,.18); font-size:12px; color:rgba(236,247,255,.86)}
.route-preview{
  margin-top:12px;
  height: 160px;
  border-radius: 16px;
  border:1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(220px 120px at 30% 30%, rgba(34,211,238,.22), transparent 60%),
    radial-gradient(220px 120px at 70% 60%, rgba(52,211,153,.16), transparent 60%),
    radial-gradient(220px 120px at 60% 45%, rgba(251,146,60,.12), transparent 60%),
    rgba(0,0,0,.18);
  overflow:hidden;
  position:relative;
}
.route-preview svg{position:absolute; inset:0; width:100%; height:100%}
.route-preview .gridlines{
  position:absolute; inset:-20px;
  background:
    linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: 44px 44px;
  opacity:.55;
  transform: rotate(-6deg);
}
.route-desc{margin-top:10px; color:rgba(236,247,255,.86); line-height:1.55; font-size:13.5px}
.route-cta{margin-top:12px; display:flex; gap:10px; flex-wrap:wrap}

.notice{
  margin-top:14px;
  padding:12px 14px;
  border-radius: 16px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.20);
  color:rgba(236,247,255,.88);
}

.form{display:grid; gap:12px}
.field label{display:block; margin-bottom:6px; color:rgba(236,247,255,.86); font-weight:700}
.field input,.field select,.field textarea{
  width:100%;
  padding:12px 12px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.22);
  color:var(--text);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}
.field textarea{min-height: 120px; resize: vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none; box-shadow: var(--focus), inset 0 1px 0 rgba(255,255,255,.06)}
.field.check{display:flex; gap:10px; align-items:flex-start}
.field.check input{width:18px; height:18px; margin-top:3px}
.hp{position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden}
.alert{
  border-radius: 16px;
  padding:12px 14px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.22);
  margin-bottom: 12px;
}
.alert ul{margin:8px 0 0; padding-left: 18px}
.alert-success{border-color: rgba(52,211,153,.25); background: rgba(52,211,153,.08)}
.alert-error{border-color: rgba(251,146,60,.25); background: rgba(251,146,60,.08)}

.site-footer{
  padding: 48px 0 44px;
  border-top:1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(255,255,255,0), rgba(255,255,255,.02));
}
.footer-grid{display:grid; grid-template-columns: 1.1fr .9fr; gap:16px}
.brand-row{display:flex; align-items:center; gap:10px}
.footer-links{display:grid; grid-template-columns: repeat(3, 1fr); gap:14px}
.footer-title{font-weight:900; margin-bottom:10px}
.footer-links a{display:block; padding:6px 0; color:rgba(236,247,255,.80); text-decoration:none}
.footer-links a:hover{color:#fff}
.footer-bottom{
  margin-top:18px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}

@media (max-width: 520px){
  .hero .cta-row{ flex-direction: column; align-items: stretch; gap: 10px; }
  .hero .cta-row .btn{ width: 100%; justify-content: center; }
  .hero-art{ min-height: 260px; }
}
@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr; gap:18px}
  .grid-4{grid-template-columns: repeat(2, 1fr)}
  .grid-3{grid-template-columns: 1fr}
  .form-grid-3{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .form-grid-2{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
}
@media (max-width: 740px){
  .nav-actions .nav-actions-desktop{ display: none !important; }
  .nav{display:none}
  .nav-toggle{display:inline-flex; align-items:center; justify-content:center; width:44px; min-width:44px; height:44px; border-radius:14px; border:1px solid var(--stroke); background:rgba(255,255,255,.03); flex-shrink:0}
  .nav-toggle:focus-visible{outline:none; box-shadow:var(--focus)}
  .nav-toggle-lines{width:18px; height:12px; position:relative}
  .nav-toggle-lines:before,.nav-toggle-lines:after{
    content:""; position:absolute; left:0; right:0; height:2px; border-radius:2px; background:rgba(236,247,255,.86);
  }
  .nav-toggle-lines:before{top:0}
  .nav-toggle-lines:after{bottom:0}
  .footer-links{grid-template-columns: repeat(2, 1fr)}
}
@media (prefers-reduced-motion: reduce){
  *{scroll-behavior:auto !important}
  .btn,.chip,.route-card{transition:none}
}

