/* ===========================================================
   ATLAS MKD — shared design tokens & components
   =========================================================== */

:root{
  --ink:      #0a0c12;
  --ink-2:    #11141d;
  --ink-3:    #171c29;
  --line:     rgba(255,255,255,.08);
  --line-2:   rgba(255,255,255,.14);
  --paper:    #eee7d6;
  --amber:    #f5a623;
  --amber-ink:#241702;
  --teal:     #2bb6a3;
  --text-hi:  #f3f1e9;
  --text-lo:  #9095ab;
  --text-dim: #5d6175;
  --radius:   18px;
  --radius-sm:10px;
}

*{box-sizing:border-box;}
html{background:var(--ink);}
body{
  margin:0;
  background:var(--ink);
  color:var(--text-hi);
  font-family:'Inter',system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;
}

a{color:inherit;text-decoration:none;}

.mono{font-family:'JetBrains Mono',monospace;}
.display{font-family:'Space Grotesk',sans-serif;}

/* ---------- background plate texture ---------- */
body{
  background-image:
    radial-gradient(circle at 12% 8%, rgba(245,166,35,.06), transparent 40%),
    radial-gradient(circle at 88% 92%, rgba(43,182,163,.05), transparent 40%),
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:auto, auto, 64px 64px, 64px 64px;
  background-position:0 0,0 0,-1px -1px,-1px -1px;
}
@media (max-width:640px){
  body{background-size:auto, auto, 40px 40px, 40px 40px;}
}

/* ---------- topbar ---------- */
.topbar{
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;
  padding:22px clamp(20px,5vw,56px) 0;
  max-width:1180px;margin:0 auto;
}
.wordmark{display:flex;align-items:center;gap:9px;}
.wordmark-mark{
  font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:13px;
  background:var(--amber);color:var(--amber-ink);
  padding:5px 8px;border-radius:6px;letter-spacing:.04em;
}
.crumb{
  font-size:12px;letter-spacing:.08em;color:var(--text-lo);
  display:flex;align-items:center;gap:8px;
}
.crumb a{color:var(--text-lo);transition:color .15s;}
.crumb a:hover{color:var(--amber);}
.crumb .sep{color:var(--text-dim);}
.crumb .here{color:var(--text-hi);}

/* ---------- shell ---------- */
.shell{max-width:1180px;margin:0 auto;padding:0 clamp(20px,5vw,56px);}

/* ---------- compass / plate corner mark ---------- */
.plate-mark{
  position:absolute;width:14px;height:14px;
  opacity:.5;pointer-events:none;
}
.plate-mark::before,.plate-mark::after{
  content:'';position:absolute;background:var(--text-lo);
}
.plate-mark::before{top:6px;left:0;width:14px;height:1px;}
.plate-mark::after{left:6px;top:0;height:14px;width:1px;}
.plate-mark.tl{top:14px;left:14px;}
.plate-mark.tr{top:14px;right:14px;}
.plate-mark.bl{bottom:14px;left:14px;}
.plate-mark.br{bottom:14px;right:14px;}

/* ---------- coordinate stamp ---------- */
.coord-stamp{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;letter-spacing:.06em;color:var(--text-lo);
  border:1px solid var(--line-2);border-radius:999px;
  padding:5px 11px 5px 9px;
}
.coord-stamp svg{flex-shrink:0;}

/* ---------- footer ---------- */
.atlas-footer{
  max-width:1180px;margin:0 auto;
  padding:40px clamp(20px,5vw,56px) 36px;
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;flex-wrap:wrap;
  border-top:1px solid var(--line);
  margin-top:64px;
  font-size:12px;color:var(--text-dim);letter-spacing:.04em;
}
.atlas-footer a{color:var(--text-lo);}
.atlas-footer a:hover{color:var(--amber);}
.footer-nav{
  width:100%;
  display:flex;gap:20px;flex-wrap:wrap;
  margin-top:14px;padding-top:14px;
  border-top:1px solid var(--line);
}
.footer-nav a{color:var(--text-lo);font-size:12px;transition:color .15s ease;}
.footer-nav a:hover{color:var(--amber);}

/* ---------- contact methods ---------- */
.contact-methods{
  display:flex;flex-direction:column;gap:12px;
  max-width:480px;margin-top:8px;
}
.contact-method{
  display:flex;align-items:center;gap:14px;
  background:var(--ink-2);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:16px 18px;
  transition:border-color .15s ease, background .15s ease;
}
.contact-method:hover{border-color:var(--line-2);background:var(--ink-3);}
.contact-method .icon{
  width:38px;height:38px;border-radius:10px;
  background:rgba(245,166,35,.12);color:var(--amber);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.contact-method .label{font-size:11px;color:var(--text-lo);letter-spacing:.04em;text-transform:uppercase;}
.contact-method .value{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:15px;margin-top:2px;}

/* ---------- legal / policy content ---------- */
.legal-copy{max-width:760px;}
.legal-copy h3{
  font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:17px;
  color:var(--text-hi);margin:32px 0 12px;
}
.legal-copy h3:first-child{margin-top:0;}
.legal-copy p{color:var(--text-lo);font-size:14px;line-height:1.75;margin:0 0 14px;}
.legal-copy ul{color:var(--text-lo);font-size:14px;line-height:1.75;margin:0 0 14px;padding-left:20px;}
.legal-copy li{margin-bottom:6px;}
.legal-copy strong{color:var(--text-hi);font-weight:600;}
.legal-updated{font-size:12px;color:var(--text-dim);margin-bottom:32px;}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14px;
  padding:11px 18px;border-radius:999px;
  border:1px solid var(--line-2);
  transition:transform .15s ease, border-color .15s ease, background .15s ease;
}
.btn:hover{transform:translateY(-1px);border-color:var(--text-lo);}
.btn.primary{
  background:var(--amber);color:var(--amber-ink);border-color:var(--amber);
}
.btn.primary:hover{background:#ffc04d;}
.btn svg{transition:transform .15s ease;}
.btn:hover svg{transform:translate(2px,-2px);}

/* ---------- logo ---------- */
.site-logo{
  width:34px;height:34px;border-radius:50%;
  display:block;flex-shrink:0;
}
.hero-logo{
  width:96px;height:96px;border-radius:50%;
  margin:0 auto 18px;display:block;
  filter:drop-shadow(0 8px 24px rgba(0,0,0,.45));
}

/* ---------- fancy lockup ---------- */
.wordmark-name{
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:16px;
  letter-spacing:.01em;
}
.wordmark-name .mkd{color:var(--amber);}

.hero-lockup{
  font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:clamp(30px,5vw,46px);letter-spacing:-.01em;
  display:flex;align-items:baseline;justify-content:center;gap:2px;
  margin:0 0 8px;
}
.hero-lockup .mkd{
  color:var(--amber);
  background:linear-gradient(120deg,#f5a623,#ffd166 55%,#f5a623);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  position:relative;
}

/* ---------- language toggle ---------- */
.lang-toggle{
  display:flex;align-items:center;gap:0;
  border:1px solid var(--line-2);border-radius:999px;
  overflow:hidden;font-family:'Space Grotesk',sans-serif;font-weight:600;
  font-size:12px;letter-spacing:.04em;
}
.lang-toggle button{
  appearance:none;border:0;background:transparent;color:var(--text-lo);
  padding:7px 13px;cursor:pointer;transition:background .15s ease,color .15s ease;
  font:inherit;
}
.lang-toggle button.active{background:var(--amber);color:var(--amber-ink);}
.topbar-right{display:flex;align-items:center;gap:14px;}

/* ---------- coming soon plates / secondary grid ---------- */
.more-cities{margin-top:54px;}
.more-cities-head{margin-bottom:18px;}
.more-cities-head .section-eyebrow{font-size:12px;letter-spacing:.12em;color:var(--text-lo);margin-bottom:6px;}
.more-cities-head h2{
  font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:clamp(20px,3vw,26px);margin:0;
}
.mini-grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:10px;
}
@media (max-width:880px){.mini-grid{grid-template-columns:repeat(4,1fr);}}
@media (max-width:620px){.mini-grid{grid-template-columns:repeat(3,1fr);}}
@media (max-width:420px){.mini-grid{grid-template-columns:repeat(2,1fr);}}

.mini-plate{
  display:flex;align-items:center;justify-content:center;
  text-align:center;
  background:var(--ink-2);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:16px 10px;transition:border-color .2s ease, transform .2s ease, background .2s ease;
}
.mini-plate:hover{border-color:var(--line-2);transform:translateY(-2px);background:var(--ink-3);}
.mini-plate .city{
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14px;
}

/* ---------- social icon button ---------- */
.social-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;
  border:1px solid var(--line-2);color:var(--text-lo);
  transition:color .15s ease, border-color .15s ease, transform .15s ease;
}
.social-btn:hover{color:var(--text-hi);border-color:var(--text-lo);transform:translateY(-1px);}

/* ---------- plate with photo backdrop (homepage) ---------- */
.plate.has-photo{
  background-image:
    linear-gradient(180deg, rgba(10,12,18,.55) 0%, rgba(10,12,18,.9) 62%, var(--ink-2) 100%),
    var(--plate-photo);
  background-size:cover;
  background-position:center top;
}

/* ---------- city banner image (hero → footer cap) ---------- */
.city-banner{
  position:relative;
  width:100%;
  height:clamp(140px,22vw,260px);
  border-radius:var(--radius);
  overflow:hidden;
  margin-top:32px;
  border:1px solid var(--line);
}
.city-banner img{
  width:100%;height:100%;object-fit:cover;object-position:center 30%;
  display:block;
}
.city-banner::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(10,12,18,0) 40%, rgba(10,12,18,.75) 100%);
}

/* ---------- full-bleed city banner with overlaid title (hub page) ---------- */
.hero-banner-full{
  position:relative;
  width:100%;
  height:clamp(260px,40vw,440px);
  overflow:hidden;
}
.hero-banner-full img{
  width:100%;height:100%;object-fit:cover;object-position:center 30%;
  display:block;
}
.hero-banner-full::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(8,9,14,.25) 0%, rgba(8,9,14,.78) 100%);
}
.hero-banner-full .banner-caption{
  position:absolute;left:0;right:0;bottom:0;
  padding:0 clamp(20px,5vw,56px) 30px;
  max-width:1180px;margin:0 auto;
}
.hero-banner-full .banner-eyebrow{
  font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.8);margin-bottom:10px;
}
.hero-banner-full h1{
  font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:clamp(42px,9vw,92px);line-height:.95;letter-spacing:-.01em;
  color:#fff;margin:0;
  text-shadow:0 2px 28px rgba(0,0,0,.5);
}

/* ---------- city navbar (flat horizontal bar, real links) ---------- */
.city-navbar{
  display:flex;width:100%;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--ink-2);
}
.city-navbar a{
  flex:1;display:flex;align-items:center;justify-content:center;
  padding:20px 16px;text-align:center;
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--text-lo);
  border-right:1px solid var(--line);
  transition:background .15s ease, color .15s ease;
}
.city-navbar a:last-child{border-right:none;}
.city-navbar a:hover{color:var(--text-hi);background:var(--ink-3);}
.city-navbar a.active{color:var(--amber-ink);background:var(--amber);}
@media (max-width:700px){
  .city-navbar{flex-direction:column;}
  .city-navbar a{border-right:none;border-bottom:1px solid var(--line);padding:16px;}
  .city-navbar a:last-child{border-bottom:none;}
}

/* ---------- city subnav (same flat-bar style, contained width — subpages) ---------- */
.subnav{
  display:flex;width:100%;
  margin-top:28px;
  border:1px solid var(--line);border-radius:var(--radius-sm);
  overflow:hidden;
  background:var(--ink-2);
}
.subnav a{
  flex:1;display:flex;align-items:center;justify-content:center;
  padding:16px 14px;text-align:center;
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:12.5px;
  letter-spacing:.07em;text-transform:uppercase;
  color:var(--text-lo);
  border-right:1px solid var(--line);
  transition:background .15s ease, color .15s ease;
}
.subnav a:last-child{border-right:none;}
.subnav a:hover{color:var(--text-hi);background:var(--ink-3);}
.subnav a.active{color:var(--amber-ink);background:var(--amber);}
@media (max-width:640px){
  .subnav{flex-direction:column;}
  .subnav a{border-right:none;border-bottom:1px solid var(--line);}
  .subnav a:last-child{border-bottom:none;}
}



/* ---------- about / article content ---------- */
.about-copy{max-width:760px;}
.about-copy p{
  color:var(--text-lo);font-size:15px;line-height:1.75;margin:0 0 18px;
}
.about-copy p:last-child{margin-bottom:0;}
.about-copy strong{color:var(--text-hi);font-weight:600;}
.placeholder-box{
  margin-top:36px;border:1px dashed var(--line-2);border-radius:var(--radius);
  padding:48px 28px;text-align:center;
}
.placeholder-box .badge{
  display:inline-block;font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text-dim);border:1px solid var(--line-2);border-radius:999px;
  padding:5px 12px;margin-bottom:16px;
}
.placeholder-box p{color:var(--text-lo);font-size:14px;max-width:420px;margin:0 auto;line-height:1.6;}
