/* =========================================================================
   SUSHI TEI INDONESIA — group / network portal
   Direction: confident holding-company portal. Two brands, one network.
   Type: Archivo (display) · Inter (body) · JetBrains Mono (data/labels).
   Palette: void ink · snow · TEI red · SHIRO amber.
   Signature: national network directory + two-brand "×" lockup.
   ========================================================================= */

:root{
  --void:#0A0C10;
  --ink:#0F1218;
  --panel:#161A21;
  --panel-2:#1D222B;
  --snow:#F3F4F6;
  --snow-2:#E8EAEE;
  --snow-3:#DCDFE5;
  --mist:#A7AFBC;
  --mist-2:#7C8493;

  --tei:#E4121F;       /* Sushi Tei red */
  --tei-2:#B30D17;
  --tei-soft:rgba(228,18,31,.12);
  --shiro:#F4A300;     /* Sushiro amber */
  --shiro-2:#D38700;
  --shiro-soft:rgba(244,163,0,.14);

  --txt:#11141A;
  --txt-on-dark:#EEF0F3;
  --line:rgba(255,255,255,.09);
  --line-2:rgba(255,255,255,.15);
  --line-ink:rgba(15,18,24,.12);
  --line-ink-2:rgba(15,18,24,.20);

  --display:"Archivo","Arial Narrow",sans-serif;
  --body:"Inter",system-ui,sans-serif;
  --mono:"JetBrains Mono","Courier New",monospace;

  --wrap:1240px;
  --gutter:clamp(1.15rem,4.5vw,3.5rem);
  --r:14px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } }
body{
  font-family:var(--body); color:var(--txt); background:var(--snow);
  line-height:1.65; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
::selection{ background:var(--tei); color:#fff; }

h1,h2,h3,h4{ font-family:var(--display); font-weight:800; line-height:1.05; letter-spacing:-.02em; }

.display{ font-family:var(--display); font-weight:800; letter-spacing:-.03em; line-height:.98;
  font-size:clamp(2.7rem,7vw,6rem); text-transform:uppercase; }
.h2{ font-family:var(--display); font-weight:800; letter-spacing:-.02em; line-height:1.02;
  font-size:clamp(1.9rem,4vw,3.4rem); text-transform:uppercase; }
.lead{ font-size:clamp(1.05rem,1.35vw,1.25rem); color:var(--mist-2); max-width:58ch; line-height:1.6; }
.section--ink .lead, .section--void .lead{ color:var(--mist); }

/* eyebrow — mono label with colored tick */
.eyebrow{ display:inline-flex; align-items:center; gap:.6rem; font-family:var(--mono);
  font-size:.72rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase; color:var(--mist-2); }
.eyebrow::before{ content:""; width:8px; height:8px; background:var(--tei); border-radius:2px; }
.eyebrow.shiro::before{ background:var(--shiro); }
.section--ink .eyebrow, .section--void .eyebrow{ color:var(--mist); }

.wrap{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(4rem,8vw,7.5rem); position:relative; }
.section--snow{ background:var(--snow); }
.section--snow2{ background:var(--snow-2); }
.section--ink{ background:var(--ink); color:var(--txt-on-dark); }
.section--void{ background:var(--void); color:var(--txt-on-dark); }
.section--ink h1,.section--ink h2,.section--ink h3,
.section--void h1,.section--void h2,.section--void h3{ color:#fff; }

/* buttons */
.btn{ display:inline-flex; align-items:center; gap:.55rem; font-family:var(--mono); font-weight:600;
  font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; padding:.95rem 1.5rem;
  border-radius:8px; border:1px solid transparent; transition:.3s var(--ease); }
.btn .ar{ transition:transform .3s var(--ease); }
.btn:hover .ar{ transform:translateX(4px); }
.btn--tei{ background:var(--tei); color:#fff; }
.btn--tei:hover{ background:var(--tei-2); }
.btn--shiro{ background:var(--shiro); color:#231a00; }
.btn--shiro:hover{ background:var(--shiro-2); }
.btn--dark{ background:#fff; color:var(--ink); }
.btn--dark:hover{ background:var(--snow-2); }
.btn--ghost{ border-color:var(--line-ink-2); color:var(--txt); }
.btn--ghost:hover{ border-color:var(--txt); }
.btn--ghost-light{ border-color:var(--line-2); color:#fff; }
.btn--ghost-light:hover{ background:rgba(255,255,255,.07); border-color:#fff; }
.btn:focus-visible{ outline:2px solid var(--shiro); outline-offset:3px; }

.tlink{ font-family:var(--mono); font-size:.82rem; font-weight:600; letter-spacing:.04em;
  border-bottom:1px solid currentColor; padding-bottom:2px; transition:color .25s var(--ease); }
.tlink:hover{ color:var(--tei); }
.section--ink .tlink:hover, .section--void .tlink:hover{ color:var(--shiro); }

/* =========================== HEADER =========================== */
.header{ position:fixed; inset:0 0 auto 0; z-index:80; height:74px; display:flex; align-items:center;
  background:rgba(10,12,16,.72); backdrop-filter:blur(14px); border-bottom:1px solid var(--line);
  transition:background .35s var(--ease), height .35s var(--ease); }
.header__inner{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:var(--gutter);
  display:flex; align-items:center; justify-content:space-between; gap:2rem; }
.brand{ display:flex; align-items:center; gap:.6rem; }
.brand__mark{ width:30px; height:30px; border-radius:7px; background:var(--tei); display:grid; place-items:center;
  font-family:var(--display); font-weight:800; color:#fff; font-size:1rem; }
.brand__name{ font-family:var(--display); font-weight:800; font-size:1.02rem; letter-spacing:.01em; color:#fff; text-transform:uppercase; line-height:1; }
.brand__name span{ color:var(--mist); font-weight:600; }
.nav{ display:flex; align-items:center; gap:1.9rem; }
.nav a{ font-family:var(--mono); font-size:.78rem; font-weight:500; letter-spacing:.04em; color:var(--mist);
  text-transform:uppercase; position:relative; padding:.3rem 0; transition:color .25s var(--ease); }
.nav a::after{ content:""; position:absolute; left:0; bottom:-3px; width:0; height:2px; background:var(--tei); transition:width .25s var(--ease); }
.nav a:hover{ color:#fff; }
.nav a:hover::after, .nav a[aria-current="page"]::after{ width:100%; }
.nav a[aria-current="page"]{ color:#fff; }
.header__cta .btn{ padding:.7rem 1.2rem; }
.burger{ display:none; width:42px; height:42px; background:transparent; border:0; position:relative; }
.burger span{ position:absolute; left:9px; right:9px; height:2px; background:#fff; transition:.3s var(--ease); }
.burger span:nth-child(1){ top:15px; } .burger span:nth-child(2){ top:21px; } .burger span:nth-child(3){ top:27px; }
.menu-open .burger span:nth-child(1){ transform:translateY(6px) rotate(45deg); }
.menu-open .burger span:nth-child(2){ opacity:0; }
.menu-open .burger span:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }

.drawer{ position:fixed; inset:0; z-index:75; background:var(--void); color:#fff; display:flex; flex-direction:column;
  justify-content:center; gap:.2rem; padding:var(--gutter); transform:translateY(-100%); transition:transform .45s var(--ease); visibility:hidden; }
.menu-open .drawer{ transform:none; visibility:visible; }
.drawer a{ font-family:var(--display); font-weight:800; text-transform:uppercase; font-size:clamp(1.9rem,8vw,2.8rem);
  padding:.45rem 0; border-bottom:1px solid var(--line); display:flex; align-items:center; justify-content:space-between; }
.drawer a .n{ font-family:var(--mono); font-size:.8rem; color:var(--tei); }
.drawer__foot{ margin-top:1.8rem; font-family:var(--mono); font-size:.78rem; color:var(--mist); }

/* =========================== HERO =========================== */
.hero{ position:relative; background:var(--void); color:#fff; padding-top:118px; padding-bottom:clamp(2.5rem,5vw,4rem); overflow:hidden; }
.hero::before{ content:""; position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(60% 50% at 85% 0%, rgba(228,18,31,.18), transparent 60%),
    radial-gradient(50% 45% at 5% 100%, rgba(244,163,0,.12), transparent 60%);
}
.hero::after{ content:""; position:absolute; inset:0; z-index:0; opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px; mask-image:radial-gradient(120% 80% at 50% 0%,#000,transparent 75%); }
.hero__inner{ position:relative; z-index:2; max-width:var(--wrap); margin-inline:auto; padding-inline:var(--gutter); }
.hero .eyebrow{ margin-bottom:1.5rem; }
.hero__title{ font-size:clamp(2.7rem,7.2vw,6.2rem); text-transform:uppercase; letter-spacing:-.03em; line-height:.97; margin-bottom:1.6rem; max-width:16ch; }
.hero__title .tei{ color:var(--tei); } .hero__title .shiro{ color:var(--shiro); }
.hero__sub{ color:var(--mist); font-size:clamp(1.05rem,1.4vw,1.28rem); max-width:54ch; margin-bottom:2.2rem; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:.9rem; margin-bottom:clamp(2.5rem,5vw,3.5rem); }

/* two-brand lockup */
.lockup{ display:inline-flex; align-items:center; gap:1.2rem; padding:1rem 1.3rem; border:1px solid var(--line);
  border-radius:var(--r); background:rgba(255,255,255,.03); }
.lockup__chip{ background:#fff; border-radius:10px; padding:.6rem 1rem; display:grid; place-items:center; min-width:120px; }
.lockup__chip img{ height:34px; width:auto; }
.lockup .x{ font-family:var(--mono); font-size:1.3rem; color:var(--mist-2); }
.lockup__label{ font-family:var(--mono); font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--mist-2); margin-left:.4rem; }

/* stat band */
.statband{ display:grid; grid-template-columns:repeat(4,1fr); border-top:1px solid var(--line); margin-top:clamp(2rem,4vw,3rem); }
.stat{ padding:1.6rem 1.4rem 0; border-right:1px solid var(--line); }
.stat:last-child{ border-right:0; }
.stat__n{ font-family:var(--display); font-weight:800; font-size:clamp(2rem,3.6vw,2.8rem); line-height:1; }
.stat__n .u{ color:var(--tei); }
.stat__l{ font-family:var(--mono); font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:var(--mist); margin-top:.5rem; }

/* =========================== SECTION HEAD =========================== */
.sec-head{ display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:1.5rem; margin-bottom:clamp(2.2rem,4vw,3.2rem); }
.sec-head .h2{ max-width:20ch; }
.sec-head__intro{ max-width:46ch; }

/* =========================== BRAND CARDS =========================== */
.brands{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.2rem,2.5vw,2rem); }
.bcard{ position:relative; border-radius:var(--r); overflow:hidden; background:var(--panel); border:1px solid var(--line);
  padding:clamp(1.6rem,3vw,2.4rem); display:flex; flex-direction:column; transition:transform .4s var(--ease), border-color .4s var(--ease); }
.bcard:hover{ transform:translateY(-4px); }
.bcard__bar{ position:absolute; inset:0 0 auto 0; height:4px; }
.bcard--tei{ border-top:0; } .bcard--tei .bcard__bar{ background:var(--tei); } .bcard--tei:hover{ border-color:var(--tei); }
.bcard--shiro .bcard__bar{ background:var(--shiro); } .bcard--shiro:hover{ border-color:var(--shiro); }
.bcard__logo{ background:#fff; border-radius:10px; padding:.9rem 1.2rem; align-self:flex-start; margin-bottom:1.4rem; }
.bcard__logo img{ height:38px; width:auto; }
.bcard__tag{ font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; margin-bottom:.7rem; }
.bcard--tei .bcard__tag{ color:var(--tei); } .bcard--shiro .bcard__tag{ color:var(--shiro); }
.bcard__title{ font-size:clamp(1.5rem,2.4vw,2rem); color:#fff; text-transform:uppercase; margin-bottom:.8rem; }
.bcard__desc{ color:var(--mist); font-size:.97rem; }
.bcard__meta{ display:flex; gap:1.6rem; margin:1.4rem 0; padding:1.2rem 0; border-block:1px solid var(--line); }
.bcard__meta div{ flex:1; }
.bcard__meta .k{ font-family:var(--mono); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--mist-2); }
.bcard__meta .v{ font-family:var(--display); font-weight:800; color:#fff; font-size:1.3rem; margin-top:.2rem; }
.bcard__foot{ margin-top:auto; }

/* =========================== NETWORK DIRECTORY =========================== */
.region{ border-top:1px solid var(--line-ink); padding-top:1.6rem; margin-top:2rem; }
.section--ink .region, .section--void .region{ border-color:var(--line); }
.region:first-of-type{ margin-top:0; }
.region__head{ display:flex; align-items:baseline; gap:.9rem; margin-bottom:1.2rem; }
.region__name{ font-family:var(--display); font-weight:800; text-transform:uppercase; font-size:1.15rem; letter-spacing:-.01em; }
.region__count{ font-family:var(--mono); font-size:.72rem; color:var(--mist-2); }
.citygrid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:.7rem; }
.cityrow{ display:flex; align-items:center; gap:.9rem; padding:.85rem 1rem; border:1px solid var(--line-ink); border-radius:10px;
  background:#fff; transition:border-color .25s var(--ease), box-shadow .25s var(--ease); }
.section--ink .cityrow, .section--void .cityrow{ background:var(--panel); border-color:var(--line); }
.cityrow:hover{ border-color:var(--line-ink-2); box-shadow:0 14px 30px -24px rgba(0,0,0,.5); }
.section--ink .cityrow:hover, .section--void .cityrow:hover{ border-color:var(--line-2); }
.cityrow__code{ font-family:var(--mono); font-size:.72rem; font-weight:700; letter-spacing:.05em; color:var(--mist-2);
  background:var(--snow-2); border-radius:6px; padding:.3rem .5rem; min-width:46px; text-align:center; }
.section--ink .cityrow__code, .section--void .cityrow__code{ background:var(--panel-2); color:var(--mist); }
.cityrow__name{ font-weight:600; font-size:.98rem; flex:1; }
.section--ink .cityrow__name, .section--void .cityrow__name{ color:#fff; }
.cityrow__links{ display:flex; gap:.4rem; }
.blink{ font-family:var(--mono); font-size:.7rem; font-weight:600; letter-spacing:.03em; text-transform:uppercase;
  padding:.4rem .6rem; border-radius:6px; display:inline-flex; align-items:center; gap:.3rem; transition:.2s var(--ease); white-space:nowrap; }
.blink--tei{ color:var(--tei); background:var(--tei-soft); }
.blink--tei:hover{ background:var(--tei); color:#fff; }
.blink--shiro{ color:var(--shiro-2); background:var(--shiro-soft); }
.blink--shiro:hover{ background:var(--shiro); color:#231a00; }
.blink .ext{ opacity:.6; font-size:.85em; }

/* cabang page: brand block + list */
.brandblock{ margin-top:clamp(2.5rem,5vw,4rem); }
.brandblock:first-of-type{ margin-top:0; }
.brandblock__head{ display:flex; align-items:center; gap:1.1rem; padding-bottom:1.2rem; margin-bottom:1.6rem; border-bottom:2px solid; }
.brandblock--tei .brandblock__head{ border-color:var(--tei); }
.brandblock--shiro .brandblock__head{ border-color:var(--shiro); }
.brandblock__logo{ background:#fff; border-radius:9px; padding:.6rem .9rem; }
.brandblock__logo img{ height:30px; width:auto; }
.brandblock__count{ margin-left:auto; font-family:var(--mono); font-size:.8rem; color:var(--mist-2); }
.linklist{ display:grid; grid-template-columns:repeat(auto-fill,minmax(250px,1fr)); gap:.6rem; }
.linkitem{ display:flex; align-items:center; gap:.8rem; padding:.85rem 1rem; border:1px solid var(--line-ink); border-radius:9px;
  background:#fff; transition:.25s var(--ease); }
.linkitem:hover{ border-color:var(--line-ink-2); transform:translateX(3px); }
.linkitem__code{ font-family:var(--mono); font-size:.7rem; font-weight:700; color:#fff; padding:.3rem .5rem; border-radius:5px; min-width:46px; text-align:center; }
.linkitem--tei .linkitem__code{ background:var(--tei); }
.linkitem--shiro .linkitem__code{ background:var(--shiro); color:#231a00; }
.linkitem__name{ font-weight:600; font-size:.96rem; flex:1; }
.linkitem__dom{ font-family:var(--mono); font-size:.72rem; color:var(--mist-2); }
.linkitem .ext{ color:var(--mist-2); }

/* =========================== TIMELINE =========================== */
.timeline{ position:relative; }
.tl{ display:grid; grid-template-columns:120px 1fr; gap:1.5rem; padding:1.6rem 0; border-top:1px solid var(--line); }
.section--snow .tl, .section--snow2 .tl{ border-color:var(--line-ink); }
.tl:first-child{ border-top:0; }
.tl__year{ font-family:var(--display); font-weight:800; font-size:clamp(1.5rem,2.6vw,2.1rem); line-height:1; }
.tl--tei .tl__year{ color:var(--tei); } .tl--shiro .tl__year{ color:var(--shiro-2); }
.tl__body h3{ font-size:1.2rem; text-transform:uppercase; margin-bottom:.4rem; }
.tl__body p{ color:var(--mist-2); font-size:.97rem; max-width:60ch; }
.section--ink .tl__body p, .section--void .tl__body p{ color:var(--mist); }

/* =========================== FEATURE GRID =========================== */
.feat{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.1rem,2.2vw,1.8rem); }
.fcard{ background:var(--panel); border:1px solid var(--line); border-radius:var(--r); padding:1.8rem 1.6rem; }
.fcard__n{ font-family:var(--mono); font-size:.78rem; color:var(--mist-2); margin-bottom:1rem; }
.fcard h3{ color:#fff; font-size:1.25rem; text-transform:uppercase; margin-bottom:.6rem; }
.fcard p{ color:var(--mist); font-size:.95rem; }

/* image slot (placeholder you can swap) */
.imgslot{ position:relative; border-radius:var(--r); overflow:hidden; min-height:340px;
  background:linear-gradient(135deg,var(--panel-2),var(--void)); border:1px solid var(--line); }
.imgslot img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.imgslot__tag{ position:absolute; left:1rem; bottom:1rem; z-index:2; font-family:var(--mono); font-size:.72rem;
  letter-spacing:.08em; text-transform:uppercase; color:var(--mist); }

/* =========================== KONTAK FORM =========================== */
.kontak-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(2rem,4vw,3.5rem); align-items:start; }
.form{ display:grid; gap:1.1rem; }
.form .row{ display:grid; grid-template-columns:1fr 1fr; gap:1.1rem; }
.field{ display:flex; flex-direction:column; gap:.45rem; }
.field label{ font-family:var(--mono); font-size:.72rem; letter-spacing:.06em; text-transform:uppercase; color:var(--mist-2); }
.field input,.field select,.field textarea{ font-family:var(--body); font-size:1rem; color:var(--txt);
  background:#fff; border:1px solid var(--line-ink-2); border-radius:9px; padding:.85rem 1rem; transition:.25s var(--ease); }
.field input:focus,.field select:focus,.field textarea:focus{ outline:0; border-color:var(--tei); box-shadow:0 0 0 3px var(--tei-soft); }
.field textarea{ resize:vertical; min-height:110px; }
.form__note{ font-size:.84rem; color:var(--mist-2); }
.infocard{ background:var(--ink); color:var(--mist); border-radius:var(--r); padding:clamp(1.6rem,3vw,2.2rem); }
.infocard h3{ color:#fff; text-transform:uppercase; font-size:1.3rem; margin-bottom:1.2rem; }
.infocard .line{ display:flex; gap:.9rem; padding:.85rem 0; border-bottom:1px solid var(--line); }
.infocard .line:last-child{ border-bottom:0; }
.infocard .k{ font-family:var(--mono); font-size:.68rem; letter-spacing:.1em; text-transform:uppercase; color:var(--mist-2); flex:0 0 92px; padding-top:.2rem; }
.infocard .v{ color:var(--txt-on-dark); font-size:.95rem; }
.infocard .v a:hover{ color:#fff; }

/* =========================== CALLOUT =========================== */
.callout{ text-align:center; }
.callout .h2{ max-width:22ch; margin:0 auto 1.2rem; }
.callout .lead{ margin:0 auto 2rem; }
.callout__actions{ display:flex; gap:.9rem; justify-content:center; flex-wrap:wrap; }

/* banner (subpages) */
.banner{ position:relative; background:var(--void); color:#fff; padding-top:130px; padding-bottom:clamp(2.5rem,5vw,4rem); overflow:hidden; }
.banner::before{ content:""; position:absolute; inset:0; z-index:0;
  background:radial-gradient(60% 60% at 80% 0%, rgba(228,18,31,.16), transparent 60%); }
.banner__inner{ position:relative; z-index:2; max-width:var(--wrap); margin-inline:auto; padding-inline:var(--gutter); }
.banner .eyebrow{ margin-bottom:1.1rem; }
.banner__title{ font-size:clamp(2.4rem,5.5vw,4.6rem); text-transform:uppercase; letter-spacing:-.03em; line-height:1; }
.crumbs{ margin-top:1rem; font-family:var(--mono); font-size:.76rem; color:var(--mist-2); }
.crumbs a:hover{ color:#fff; }

/* =========================== FOOTER =========================== */
.footer{ background:var(--void); color:var(--mist-2); padding-block:clamp(3.5rem,6vw,5rem) 2rem; border-top:1px solid var(--line); }
.footer__top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:2rem; }
.footer__brand .brand{ margin-bottom:1.1rem; }
.footer__brand p{ max-width:36ch; font-size:.92rem; color:var(--mist-2); }
.footer__lockup{ display:flex; gap:.7rem; margin-top:1.4rem; }
.footer__lockup span{ background:#fff; border-radius:8px; padding:.5rem .8rem; }
.footer__lockup img{ height:24px; width:auto; }
.fcol h4{ font-family:var(--mono); color:#fff; font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; margin-bottom:1rem; }
.fcol a,.fcol p{ display:block; font-size:.92rem; color:var(--mist-2); padding:.3rem 0; transition:color .25s var(--ease); }
.fcol a:hover{ color:#fff; }
.footer__bottom{ margin-top:clamp(2.2rem,4vw,3rem); padding-top:1.5rem; border-top:1px solid var(--line);
  display:flex; flex-wrap:wrap; gap:1rem; justify-content:space-between; font-family:var(--mono); font-size:.74rem; color:var(--mist-2); }

/* reveal */
.reveal{ opacity:0; transform:translateY(20px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.07s; } .reveal[data-d="2"]{ transition-delay:.14s; } .reveal[data-d="3"]{ transition-delay:.21s; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

/* =========================== RESPONSIVE =========================== */
@media (max-width:1000px){
  .nav, .header__cta{ display:none; }
  .burger{ display:block; }
  .brands{ grid-template-columns:1fr; }
  .feat{ grid-template-columns:1fr; }
  .kontak-grid{ grid-template-columns:1fr; }
  .statband{ grid-template-columns:1fr 1fr; }
  .stat{ border-bottom:1px solid var(--line); padding-bottom:1.4rem; }
  .stat:nth-child(2){ border-right:0; }
  .footer__top{ grid-template-columns:1fr 1fr; }
}
@media (max-width:600px){
  .statband{ grid-template-columns:1fr; } .stat{ border-right:0; }
  .tl{ grid-template-columns:1fr; gap:.5rem; }
  .form .row{ grid-template-columns:1fr; }
  .footer__top{ grid-template-columns:1fr; }
  .citygrid, .linklist{ grid-template-columns:1fr; }
  .cityrow{ flex-wrap:wrap; }
  .sec-head{ flex-direction:column; align-items:flex-start; }
}

/* =========================================================================
   UPGRADE PASS — motion, Japanese accents, hero art, ticker, FAQ
   ========================================================================= */

/* scroll progress bar */
.progress{ position:fixed; top:0; left:0; height:3px; width:0%; z-index:95;
  background:linear-gradient(90deg,var(--tei),var(--shiro)); box-shadow:0 0 12px rgba(244,163,0,.4); transition:width .08s linear; }

/* header: shrink + auto-hide */
.header{ transition:transform .45s var(--ease), background .35s var(--ease), height .35s var(--ease), border-color .35s var(--ease); }
.header.scrolled{ height:62px; background:rgba(10,12,16,.92); border-color:var(--line-2); }
.header.hide{ transform:translateY(-100%); }

/* kanji accents */
.eyebrow .jp{ font-family:"Noto Sans JP",var(--display); font-weight:700; font-size:1rem; letter-spacing:.06em; color:var(--tei); }
.eyebrow.shiro .jp{ color:var(--shiro); }
.section--ink .eyebrow .jp, .section--void .eyebrow .jp{ color:var(--tei); }
.jp-watermark{ position:absolute; font-family:"Noto Sans JP",serif; font-weight:700; line-height:.8;
  font-size:clamp(8rem,22vw,18rem); color:#fff; opacity:.025; pointer-events:none; user-select:none; z-index:0;
  top:50%; right:2%; transform:translateY(-50%); }
.section{ overflow:hidden; }
.section > .wrap{ position:relative; z-index:1; }

/* hero — two columns + art + staggered entrance */
.hero__grid{ display:grid; grid-template-columns:1.12fr .88fr; gap:clamp(2rem,4vw,3.5rem); align-items:center; }
.hero__art{ position:relative; }
.hero__art img{ width:100%; height:auto; border-radius:18px; box-shadow:0 50px 90px -50px rgba(0,0,0,.8); }
.hero__art .badge{ position:absolute; left:-14px; top:26px; background:#fff; color:#0A0C10; border-radius:10px;
  padding:.7rem 1rem; font-family:var(--mono); font-size:.72rem; font-weight:700; letter-spacing:.06em; box-shadow:0 20px 40px -20px rgba(0,0,0,.6); }
.hero__art .badge .jp{ font-family:"Noto Sans JP",serif; color:var(--tei); margin-right:.4rem; }

@keyframes riseIn{ from{ opacity:0; transform:translateY(26px); } to{ opacity:1; transform:none; } }
@keyframes artIn{ from{ opacity:0; transform:translateY(30px) scale(.97); } to{ opacity:1; transform:none; } }
.hero [data-anim]{ opacity:0; animation:riseIn .85s var(--ease) forwards; }
.hero [data-anim="1"]{ animation-delay:.04s; } .hero [data-anim="2"]{ animation-delay:.12s; }
.hero [data-anim="3"]{ animation-delay:.2s; }  .hero [data-anim="4"]{ animation-delay:.28s; }
.hero [data-anim="5"]{ animation-delay:.36s; }
.hero__art{ opacity:0; animation:artIn 1s var(--ease) .22s forwards; }

/* animated hero glow */
.hero::before{ animation:glow 14s ease-in-out infinite alternate; }
@keyframes glow{ 0%{ opacity:.7; } 100%{ opacity:1; transform:scale(1.06); } }

/* city ticker */
.ticker{ background:var(--void); border-block:1px solid var(--line); overflow:hidden; position:relative; }
.ticker::before,.ticker::after{ content:""; position:absolute; top:0; bottom:0; width:90px; z-index:2; pointer-events:none; }
.ticker::before{ left:0; background:linear-gradient(90deg,var(--void),transparent); }
.ticker::after{ right:0; background:linear-gradient(270deg,var(--void),transparent); }
.ticker__track{ display:flex; width:max-content; animation:tick 42s linear infinite; }
.ticker:hover .ticker__track{ animation-play-state:paused; }
.ticker__item{ display:inline-flex; align-items:center; gap:.6rem; padding:.95rem 1.5rem; font-family:var(--mono);
  font-size:.8rem; color:var(--mist); white-space:nowrap; }
.ticker__item b{ font-family:var(--display); font-weight:800; color:#fff; letter-spacing:.01em; }
.ticker__item .dot{ width:6px; height:6px; border-radius:50%; background:var(--tei); }
.ticker__item .dot.s{ background:var(--shiro); }
@keyframes tick{ to{ transform:translateX(-50%); } }

/* count-up: keep layout stable */
.stat__n [data-count]{ font-variant-numeric:tabular-nums; }

/* richer hovers */
.bcard__bar{ transition:height .35s var(--ease); }
.bcard--tei:hover .bcard__bar, .bcard--shiro:hover .bcard__bar{ height:7px; }
.bcard{ transition:transform .45s var(--ease), border-color .45s var(--ease), box-shadow .45s var(--ease); }
.bcard:hover{ box-shadow:0 40px 80px -50px rgba(0,0,0,.7); }
.btn{ position:relative; overflow:hidden; }
.btn::after{ content:""; position:absolute; inset:0; background:rgba(255,255,255,.16); transform:translateX(-101%); transition:transform .5s var(--ease); }
.btn:hover::after{ transform:translateX(101%); }
.cityrow{ transition:border-color .25s var(--ease), box-shadow .25s var(--ease), transform .25s var(--ease); }
.cityrow:hover{ transform:translateY(-2px); }

/* reveal: add a soft scale variant */
.reveal{ transition:opacity .7s var(--ease), transform .7s var(--ease); }

/* FAQ accordion */
.faq{ display:grid; gap:.75rem; max-width:880px; }
.faq__item{ border:1px solid var(--line-ink); border-radius:12px; background:#fff; overflow:hidden; transition:border-color .3s var(--ease); }
.section--ink .faq__item, .section--void .faq__item{ background:var(--panel); border-color:var(--line); }
.faq__item.open{ border-color:var(--line-ink-2); }
.section--ink .faq__item.open, .section--void .faq__item.open{ border-color:var(--line-2); }
.faq__q{ width:100%; text-align:left; display:flex; align-items:center; justify-content:space-between; gap:1rem;
  padding:1.15rem 1.35rem; background:transparent; border:0; color:inherit; cursor:pointer;
  font-family:var(--display); font-weight:700; text-transform:uppercase; font-size:1rem; letter-spacing:-.01em; }
.faq__q .ico{ font-family:var(--mono); color:var(--tei); transition:transform .3s var(--ease); flex:0 0 auto; }
.faq__item.open .faq__q .ico{ transform:rotate(45deg); }
.faq__a{ max-height:0; overflow:hidden; transition:max-height .4s var(--ease); }
.faq__a p{ padding:0 1.35rem 1.25rem; color:var(--mist-2); font-size:.97rem; }
.section--ink .faq__a p, .section--void .faq__a p{ color:var(--mist); }

@media (max-width:1000px){
  .hero__grid{ grid-template-columns:1fr; }
  .hero__art{ max-width:440px; }
  .jp-watermark{ display:none; }
}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  .hero [data-anim], .hero__art{ opacity:1; animation:none; }
  .hero::before{ animation:none; }
  .ticker__track{ animation:none; }
  .btn::after{ display:none; }
  .progress{ display:none; }
}
.brand{
    display:flex;
    align-items:center;
    gap:12px;
    text-decoration:none;
}

.brand__logo{
    width:42px;
    height:42px;
    object-fit:contain;
    display:block;
}

.brand__name{
    font-size:1.5rem;
    font-weight:800;
    color:#fff;
    line-height:1;
}

.brand__name span{
    color:#cfcfcf;
}
.footer .brand{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
}

.footer .brand__logo{
  width:52px;
  height:auto;
  object-fit:contain;
  display:block;
}

.footer .brand__name{
  font-size:28px;
  font-weight:800;
  color:#fff;
  line-height:1;
}

.footer .brand__name span{
  color:#c9ced8;
}