:root{
  --bg:#f6f8fb;
  --surface:#ffffff;
  --surface-alt:#eef2f7;
  --text:#17202c;
  --muted:#5f6b7a;
  --border:#dbe2ea;
  --accent:#0b68b7;
  --accent-strong:#084f8e;
  --on-accent:#ffffff;
  --glass:color-mix(in srgb, #ffffff 78%, transparent);
  --glass-strong:color-mix(in srgb, #ffffff 92%, transparent);
  --ring:color-mix(in srgb, var(--accent) 22%, transparent);
  --shadow:0 16px 42px rgba(26,39,58,.12);
  --radius:8px;
  --max:1180px;
  --media-text:#ffffff;
  --media-muted:rgba(255,255,255,.78);
  --media-overlay:rgba(0,0,0,.58);
  --media-overlay-strong:rgba(0,0,0,.68);
  --media-control-bg:#ffffff;
  --media-control-text:#09090a;
  --media-control-soft:rgba(14,14,15,.68);
  color-scheme:light;
}

html.dark{
  --bg:#000000;
  --surface:#0a0a0b;
  --surface-alt:#161618;
  --text:#f4f6f8;
  --muted:#b7bec8;
  --border:#303034;
  --accent:#5ab8ff;
  --accent-strong:#b3ddff;
  --on-accent:#050505;
  --glass:color-mix(in srgb, #111113 76%, transparent);
  --glass-strong:color-mix(in srgb, #151518 90%, transparent);
  --ring:color-mix(in srgb, var(--accent) 34%, transparent);
  --shadow:0 18px 48px rgba(0,0,0,.48);
  color-scheme:dark;
}

*{ box-sizing:border-box; }

html{ min-height:100%; background:var(--bg); }

body{
  margin:0;
  min-height:100%;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  color:var(--text);
  background:var(--bg);
}

a{ color:inherit; text-decoration:none; }
img, video{ max-width:100%; }
button, input, textarea{ font:inherit; }

.page{ padding:26px 18px 60px; }
.shell{ max-width:var(--max); margin:0 auto; }
.hairline{ height:1px; background:var(--border); }
.muted{ color:var(--muted); }

.topbar{
  position:sticky;
  top:0;
  z-index:50;
  padding:16px 18px;
  background:color-mix(in srgb, var(--bg) 88%, transparent);
  backdrop-filter:blur(14px);
}

.topbar__inner{
  max-width:var(--max);
  margin:0 auto;
  min-height:58px;
  display:flex;
  align-items:center;
  gap:18px;
  position:relative;
}

.brand{ display:flex; align-items:center; flex:0 0 auto; }
.brand__logo{ display:none; height:48px; width:auto; max-width:230px; object-fit:contain; }
html.dark .brand__logo--dark{ display:block; }
html:not(.dark) .brand__logo--light{ display:block; }

.navPill{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  align-items:center;
  gap:4px;
  max-width:calc(100% - 150px);
  padding:6px;
  border:1px solid var(--border);
  border-radius:999px;
  background:var(--surface);
  box-shadow:var(--shadow);
  overflow-x:auto;
  scrollbar-width:none;
}
.navPill::-webkit-scrollbar{ display:none; }

.navPill__item{
  flex:0 0 auto;
  padding:10px 14px;
  border-radius:999px;
  color:var(--muted);
  font-size:14px;
  font-weight:700;
  white-space:nowrap;
}
.navPill__item:hover,
.navPill__item.is-active{
  color:var(--text);
  background:var(--surface-alt);
}

.themeBtn{
  margin-left:auto;
  width:70px;
  height:38px;
  border:1px solid var(--border);
  border-radius:999px;
  background:var(--glass-strong);
  color:var(--text);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:3px;
  cursor:pointer;
  box-shadow:var(--shadow);
  backdrop-filter:blur(16px) saturate(150%);
}
.themeBtn__track{
  position:relative;
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 9px;
  border-radius:999px;
  background:var(--surface-alt);
}
.themeBtn__sun,
.themeBtn__moon{
  position:relative;
  z-index:2;
  width:13px;
  height:13px;
  border-radius:999px;
}
.themeBtn__sun{
  color:var(--text);
  background:currentColor;
  border:0;
  box-shadow:none;
}
.themeBtn__moon{
  color:var(--text);
  background:transparent;
  box-shadow:-4px 0 0 currentColor;
}
.themeBtn__knob{
  position:absolute;
  z-index:1;
  left:3px;
  top:3px;
  width:30px;
  height:30px;
  border-radius:999px;
  background:var(--surface);
  border:1px solid var(--border);
  box-shadow:0 8px 20px rgba(0,0,0,.16);
  transition:transform .25s ease;
}
.themeBtn[aria-pressed="true"] .themeBtn__knob{
  transform:translateX(32px);
}

.welcomeHero{
  width:calc(100% + 36px);
  min-height:calc(100svh - 91px);
  margin:-26px -18px 0;
  display:grid;
  place-items:center;
  position:relative;
  overflow:hidden;
  isolation:isolate;
  background-color:var(--bg);
  background-position:center;
  background-size:cover;
  border-bottom:1px solid var(--border);
}
.welcomeHero::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:var(--media-overlay);
  opacity:0;
}
.welcomeHero--media::before{ opacity:1; }
.welcomeHero__inner{
  position:relative;
  z-index:1;
  width:100%;
  max-width:1040px;
  padding:96px 32px 110px;
  text-align:center;
}
.welcomeHero__title{
  max-width:980px;
  margin:0 auto;
  color:var(--text);
  font-size:80px;
  line-height:1.04;
  font-weight:780;
  letter-spacing:0;
  text-wrap:balance;
  animation:welcomeReveal .8s .08s ease both;
}
.welcomeHero__copy{
  max-width:790px;
  margin:26px auto 0;
  color:var(--muted);
  font-size:18px;
  line-height:1.75;
  animation:welcomeReveal .8s .16s ease both;
}
.welcomeHero__copy p{ margin:0; }
.welcomeHero__actions{
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:12px;
  margin-top:30px;
  animation:welcomeReveal .8s .24s ease both;
}
.welcomeHero__actions .btn{
  min-width:156px;
  justify-content:center;
}
.welcomeHero--media .welcomeHero__title{ color:var(--media-text); }
.welcomeHero--media .welcomeHero__copy{ color:var(--media-muted); }
.welcomeHero--media .btn.btn--primary,
.introPanel--media .btn.btn--primary{
  color:var(--media-control-text);
  background:var(--media-control-bg);
  border-color:var(--media-control-bg);
}
.welcomeHero--media .btn.btn--pill,
.introPanel--media .btn.btn--pill{
  color:var(--media-text);
  background:var(--media-control-soft);
  border-color:color-mix(in srgb, var(--media-text) 24%, transparent);
}
@keyframes welcomeReveal{
  from{ opacity:0; transform:translateY(16px); }
  to{ opacity:1; transform:translateY(0); }
}
.introPanel{
  min-height:560px;
  margin-top:28px;
  padding:72px 64px;
  display:flex;
  align-items:center;
  position:relative;
  overflow:hidden;
  isolation:isolate;
  background-color:var(--surface);
  background-position:center;
  background-size:cover;
  border:1px solid var(--border);
}
.introPanel::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:var(--media-overlay);
  opacity:0;
}
.introPanel--media::before{ opacity:1; }
.introPanel__content{
  width:min(650px, 100%);
  position:relative;
  z-index:1;
}
.introPanel__eyebrow{
  margin-bottom:18px;
  color:var(--muted);
  font-size:13px;
  line-height:1;
  font-weight:750;
  text-transform:uppercase;
}
.introPanel__title{
  margin:0;
  max-width:640px;
  color:var(--text);
  font-size:54px;
  line-height:1.08;
  font-weight:780;
  letter-spacing:0;
  text-wrap:balance;
}
.introPanel__copy{
  max-width:620px;
  margin-top:26px;
  color:var(--muted);
  font-size:17px;
  line-height:1.72;
}
.introPanel__copy p{ margin:0 0 18px; }
.introPanel__copy p:last-child{ margin-bottom:0; }
.introPanel__actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:30px;
}
.introPanel--media .introPanel__eyebrow,
.introPanel--media .introPanel__title{ color:var(--media-text); }
.introPanel--media .introPanel__copy{ color:var(--media-muted); }

.hero{ margin-top:18px; }
.hero__frame{
  position:relative;
  overflow:hidden;
  padding:18px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--surface);
  box-shadow:var(--shadow);
  backdrop-filter:blur(18px) saturate(145%);
}
.hero__track{ display:flex; transition:transform .45s ease; }
.hero__frame.isDragging .hero__track{ transition:none; }
.hero__slide{ flex:0 0 100%; min-width:100%; position:relative; }
.hero__media{
  display:block;
  width:100%;
  height:clamp(320px, 42vw, 620px);
  object-fit:contain;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--surface-alt);
}
.hero__media--empty{ min-height:320px; }
.hero__card{
  position:absolute;
  left:24px;
  bottom:24px;
  width:min(360px, calc(100% - 48px));
  padding:16px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:color-mix(in srgb, var(--surface) 86%, transparent);
  box-shadow:var(--shadow);
  backdrop-filter:blur(16px) saturate(145%);
}
.hero__cardTitle{ font-size:22px; font-weight:850; }
.hero__cardText{ margin-top:6px; color:var(--muted); line-height:1.55; }
.hero__nav{
  position:absolute;
  top:50%;
  width:42px;
  height:42px;
  transform:translateY(-50%);
  border:1px solid var(--border);
  border-radius:999px;
  background:var(--surface);
  color:var(--text);
  box-shadow:var(--shadow);
  cursor:pointer;
  font-size:24px;
  line-height:1;
}
.hero__nav--prev{ left:20px; }
.hero__nav--next{ right:20px; }
.hero__dots{
  display:flex;
  justify-content:center;
  gap:8px;
  margin-top:12px;
}
.hero__dots button{
  width:7px;
  height:7px;
  padding:0;
  border:0;
  border-radius:999px;
  background:var(--border);
  cursor:pointer;
}
.hero__dots button.is-active{ background:var(--accent); }
.hero__progress{
  position:absolute;
  left:18px;
  right:18px;
  bottom:12px;
  height:3px;
  overflow:hidden;
  border-radius:999px;
  background:var(--border);
}
.hero__progress span{
  display:block;
  width:0%;
  height:100%;
  background:var(--accent);
}

.section{ margin-top:28px; }
.section__title,
.sectionHead__title,
.h2{
  margin:0 0 14px;
  font-size:22px;
  line-height:1.2;
  font-weight:850;
}
.pageTitle{
  margin:0 0 16px;
  font-size:clamp(30px, 4vw, 46px);
  line-height:1.08;
  font-weight:900;
}
.pageHero{
  padding:28px 0 8px;
}
.pageHero__title{
  margin:0;
  font-size:clamp(34px, 5vw, 56px);
  line-height:1.05;
}
.pageHero__sub{
  max-width:720px;
  margin:10px 0 0;
  color:var(--muted);
  line-height:1.65;
}

.cardRow{
  display:flex;
  gap:14px;
  overflow-x:auto;
  padding-bottom:6px;
}
.cardGrid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:14px;
}
.card,
.projCard,
.docCard,
.policyCard,
.contactCard,
.locationCard,
.statusCard,
.wideCard{
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--surface);
  box-shadow:var(--shadow);
}
.card{
  display:flex;
  gap:14px;
  min-width:320px;
  padding:14px;
}
.card--grid{ min-width:0; flex-direction:column; }
.card__thumb{
  width:120px;
  height:92px;
  flex:0 0 auto;
  display:grid;
  place-items:center;
  overflow:hidden;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--surface-alt);
}
.card--grid .card__thumb{ width:100%; height:170px; }
.card__thumb img{ width:100%; height:100%; object-fit:contain; }
.card__meta{ display:flex; flex-direction:column; align-items:flex-start; gap:8px; }
.card__title{ font-weight:850; }
.card__text{ color:var(--muted); font-size:14px; line-height:1.55; }

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:40px;
  padding:10px 15px;
  border:1px solid var(--border);
  border-radius:999px;
  background:var(--surface-alt);
  color:var(--text);
  font-size:14px;
  font-weight:800;
  cursor:pointer;
}
.btn:hover{ border-color:var(--accent); color:var(--accent-strong); }
.btn--primary{
  border-color:var(--accent);
  background:var(--accent);
  color:var(--on-accent);
}
.btn--primary:hover{ color:var(--on-accent); background:var(--accent-strong); }
.btn--pill{ width:fit-content; }
.btn--ghost{ margin-top:10px; }

.wideCard{
  display:grid;
  grid-template-columns:1fr 320px;
  gap:18px;
  padding:18px;
  align-items:stretch;
}
.wideCard__kicker{ color:var(--accent-strong); font-size:13px; font-weight:850; }
.wideCard__title{ margin-top:6px; font-size:24px; font-weight:900; }
.wideCard__text{ margin-top:8px; color:var(--muted); line-height:1.55; }
.wideCard__actions{ margin-top:14px; display:flex; gap:10px; flex-wrap:wrap; }
.wideCard__right{
  display:grid;
  place-items:center;
  min-height:130px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--surface-alt);
}
.wideCard__mock{ color:var(--muted); font-weight:900; }

.docGrid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px;
}
.docCard{
  display:block;
  padding:16px;
}
.docCard__thumb{
  height:130px;
  margin-bottom:12px;
  overflow:hidden;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--surface-alt);
}
.docCard__thumb img{ width:100%; height:100%; object-fit:contain; }
.docCard__title{ font-weight:850; }
.docCard__sub,
.docCard__cta{
  margin-top:6px;
  color:var(--muted);
  font-size:14px;
  line-height:1.55;
}
.docCard__actions,
.docActions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:12px;
}

.policyGrid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
}
.policyCard{
  display:block;
  padding:16px;
}
.policyCard__title{ font-size:17px; font-weight:850; }
.policyCard__excerpt{ margin-top:8px; color:var(--muted); line-height:1.6; }
.policyCard__hint{ margin-top:12px; color:var(--accent-strong); font-weight:800; }

.projCard{
  display:block;
  overflow:hidden;
}
.projCard__thumb{
  height:170px;
  display:grid;
  place-items:center;
  background:var(--surface-alt);
  border-bottom:1px solid var(--border);
}
.projCard__thumb img{ width:100%; height:100%; object-fit:contain; }
.projCard__body{ padding:14px; }
.projCard__title{ font-weight:850; }
.projCard__sub{ margin-top:6px; color:var(--muted); line-height:1.5; }

.marquee{
  overflow:hidden;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--surface);
}
.marquee__track{
  display:flex;
  gap:12px;
  width:max-content;
  padding:14px;
  animation:marquee 32s linear infinite;
}
@keyframes marquee{
  from{ transform:translateX(0); }
  to{ transform:translateX(-50%); }
}
.refPill{
  min-width:140px;
  height:56px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 16px;
  border:1px solid var(--border);
  border-radius:999px;
  background:var(--surface-alt);
}
.refPill img{ max-width:118px; max-height:30px; object-fit:contain; }
.refPill span{ font-weight:800; color:var(--muted); }

.detailFrame{
  margin-top:18px;
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:18px;
  padding:18px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--surface);
  box-shadow:var(--shadow);
}
.detailFrame__mainImg{
  width:100%;
  height:420px;
  display:block;
  object-fit:contain;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--surface-alt);
}
.detailFrame__empty{ min-height:320px; }
.detailFrame__thumbs{
  display:flex;
  gap:10px;
  margin-top:12px;
  overflow-x:auto;
  padding-bottom:4px;
}
.thumb{
  flex:0 0 auto;
  width:86px;
  height:62px;
  padding:0;
  overflow:hidden;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--surface-alt);
  cursor:pointer;
}
.thumb img{ width:100%; height:100%; object-fit:contain; }
.kicker{ color:var(--accent-strong); font-size:13px; font-weight:850; }
.detailTitle{ margin:6px 0 14px; font-size:32px; line-height:1.12; font-weight:900; }
.h3{ margin:18px 0 8px; font-size:16px; font-weight:850; }
.text,
.prose{
  color:var(--muted);
  line-height:1.8;
}
.prose{ max-width:760px; }
.prose--wide{ max-width:920px; margin-top:18px; }

.contactGrid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:16px;
  align-items:start;
}
.contactCard{ padding:18px; }
.form{ margin-top:10px; }
.formRow{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
  margin-bottom:12px;
}
.formRow--single{ grid-template-columns:1fr; }
.label{
  display:block;
  margin-bottom:6px;
  color:var(--muted);
  font-size:13px;
  font-weight:800;
}
.input,
.textarea{
  width:100%;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--surface-alt);
  color:var(--text);
  padding:12px 14px;
  outline:none;
}
.textarea{ min-height:140px; resize:vertical; }
.input:focus,
.textarea:focus{ border-color:var(--accent); box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 20%, transparent); }
.stack{ display:grid; gap:14px; }
.locationCard{ padding:14px; box-shadow:none; }
.locationCard__title{ font-weight:850; margin-bottom:6px; }
.locationCard__links{
  display:grid;
  gap:4px;
  margin-top:10px;
  color:var(--accent-strong);
  font-weight:700;
}
.mapFrame{
  width:100%;
  aspect-ratio:16/9;
  margin-top:12px;
  border:0;
  border-radius:var(--radius);
}
.statusCard{ padding:22px; }

.footer{
  margin-top:42px;
  padding:22px 18px;
  border-top:1px solid var(--border);
}
.footer__inner{
  max-width:var(--max);
  margin:0 auto;
  display:grid;
  gap:18px;
}
.footer__main{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:16px;
  flex-wrap:wrap;
}
.footer__brand{ font-weight:900; }
.footer__muted,
.footer__link{ color:var(--muted); font-size:14px; }
.footer__right{ display:flex; gap:12px; flex-wrap:wrap; }
.footer__link:hover{ color:var(--accent-strong); }
.footer__partner{
  display:inline-flex;
  align-items:center;
  justify-self:start;
  flex:0 0 auto;
  width:max-content;
  padding:6px 0;
  opacity:.68;
  transition:opacity .2s ease, transform .2s ease;
}
.footer__partner:hover{
  opacity:1;
  transform:translateY(-1px);
}
.footer__partnerLogo{
  display:none;
  width:150px;
  height:auto;
  max-height:30px;
  object-fit:contain;
}
html:not(.dark) .footer__partnerLogo--light{ display:block; }
html.dark .footer__partnerLogo--dark{ display:block; }

@media (max-width:980px){
  .welcomeHero{
    width:calc(100% + 28px);
    margin-left:-14px;
    margin-right:-14px;
  }
  .welcomeHero__inner{ padding:68px 22px 82px; }
  .welcomeHero__title{ font-size:56px; }
  .introPanel{ min-height:520px; padding:56px 44px; }
  .introPanel__title{ font-size:46px; }
  .topbar__inner{
    justify-content:center;
    flex-wrap:wrap;
    gap:12px;
  }
  .brand{
    flex:0 0 100%;
    justify-content:center;
  }
  .brand__logo{
    height:56px;
    max-width:min(72vw, 260px);
  }
  .themeBtn{
    position:absolute;
    top:16px;
    right:0;
    margin-left:0;
  }
  .navPill{
    position:static;
    transform:none;
    order:3;
    width:100%;
    max-width:100%;
    justify-content:flex-start;
  }
  .page{ padding-inline:14px; }
  .hero__media{
    height:auto;
    min-height:0;
    aspect-ratio:16/9;
  }
  .hero__slide{
    display:flex;
    flex-direction:column;
    gap:12px;
  }
  .hero__card{
    position:static;
    width:100%;
    box-shadow:none;
  }
  .hero__progress{ display:none; }
  .cardGrid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
  .docGrid{ grid-template-columns:1fr; }
  .policyGrid{ grid-template-columns:1fr; }
  .wideCard{ grid-template-columns:1fr; }
  .detailFrame{ grid-template-columns:1fr; }
  .contactGrid{ grid-template-columns:1fr; }
}

@media (max-width:620px){
  .welcomeHero__inner{ padding:48px 4px 58px; }
  .welcomeHero__title{ font-size:40px; line-height:1.08; }
  .welcomeHero__copy{ margin-top:20px; font-size:16px; line-height:1.65; }
  .welcomeHero__actions{ margin-top:24px; gap:10px; }
  .welcomeHero__actions .btn{ min-width:140px; }
  .introPanel{
    min-height:540px;
    padding:42px 24px;
    background-position:68% center;
  }
  .introPanel::before{ background:var(--media-overlay-strong); }
  .introPanel__title{ font-size:36px; }
  .introPanel__copy{ margin-top:20px; font-size:15px; line-height:1.65; }
  .introPanel__actions{ margin-top:24px; }
  .introPanel__actions .btn{ width:100%; justify-content:center; }
  .topbar{ padding:10px 12px; }
  .topbar__inner{ min-height:48px; gap:8px; }
  .brand__logo{
    height:46px;
    max-width:min(68vw, 220px);
  }
  .themeBtn{
    top:5px;
    width:38px;
    height:38px;
  }
  .navPill{
    padding:4px;
    gap:2px;
  }
  .navPill__item{
    padding:8px 10px;
    font-size:13px;
  }
  .hero__frame{ padding:10px; }
  .hero__nav{
    width:36px;
    height:36px;
    font-size:22px;
  }
  .hero__nav--prev{ left:14px; }
  .hero__nav--next{ right:14px; }
  .cardGrid{ grid-template-columns:1fr; }
  .card{
    min-width:280px;
    flex-direction:column;
  }
  .card__thumb,
  .card--grid .card__thumb{ width:100%; height:168px; }
  .formRow{ grid-template-columns:1fr; }
  .wideCard__right{ min-height:90px; }
  .detailFrame__mainImg{ height:320px; }
  .footer__main{ display:grid; }
  .footer__partnerLogo{ width:138px; }
}

@media (max-width:420px){
  .welcomeHero__title{ font-size:36px; }
  .welcomeHero__copy{ font-size:15px; }
}

@media (prefers-reduced-motion:reduce){
  .welcomeHero__title,
  .welcomeHero__copy,
  .welcomeHero__actions{
    animation:none;
  }
}

.topbar{
  background:color-mix(in srgb, var(--bg) 72%, transparent);
  box-shadow:0 1px 0 var(--border);
}

.navPill,
.card,
.projCard,
.docCard,
.policyCard,
.contactCard,
.locationCard,
.statusCard,
.wideCard,
.detailFrame,
.marquee{
  background:var(--glass);
  backdrop-filter:blur(18px) saturate(145%);
}

.card,
.projCard,
.docCard,
.policyCard,
.contactCard,
.locationCard,
.statusCard,
.wideCard,
.detailFrame{
  position:relative;
  overflow:hidden;
}

.card::before,
.projCard::before,
.docCard::before,
.policyCard::before,
.contactCard::before,
.locationCard::before,
.statusCard::before,
.wideCard::before,
.detailFrame::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  border-radius:inherit;
  background:
    linear-gradient(135deg, color-mix(in srgb, #fff 26%, transparent), transparent 38%),
    radial-gradient(circle at 18% 0%, color-mix(in srgb, var(--accent) 13%, transparent), transparent 34%);
  opacity:.55;
}

.card > *,
.projCard > *,
.docCard > *,
.policyCard > *,
.contactCard > *,
.locationCard > *,
.statusCard > *,
.wideCard > *,
.detailFrame > *{
  position:relative;
}

.hero--page{
  margin-top:18px;
}
.hero__frame--page .hero__media{
  height:clamp(300px, 38vw, 540px);
}

.wideCard__shop{
  width:100%;
  min-height:132px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:14px;
  padding:18px;
  color:var(--text);
}
.wideCard__shopLogo{
  width:min(210px, 78%);
  max-height:62px;
  object-fit:contain;
}
.wideCard__shopLink{
  padding:8px 14px;
  border:1px solid var(--border);
  border-radius:999px;
  background:var(--glass-strong);
  color:var(--accent-strong);
  font-weight:900;
}

.policyCard__button{
  margin-top:14px;
}

.contactGrid--wide{
  grid-template-columns:minmax(260px, 340px) minmax(0, 1fr);
}
.contactMain{
  display:grid;
  gap:16px;
}
.contactTree{
  position:sticky;
  top:108px;
}
.contactTree__list{
  display:grid;
  gap:12px;
}
.contactTree__item,
.contactTree__child{
  padding:14px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--surface-alt);
}
.contactTree__title{
  font-weight:900;
}
.contactTree__desc,
.contactTree__child span{
  display:block;
  margin-top:6px;
  color:var(--muted);
  line-height:1.55;
}
.contactTree__links{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
}
.contactTree__links a{
  color:var(--accent-strong);
  font-weight:800;
}
.contactTree__children{
  display:grid;
  gap:8px;
  margin-top:10px;
}

.detailFrame__stage{
  position:relative;
}
.detailFrame__mainImg{
  height:min(68vh, 640px);
  min-height:390px;
  padding:10px;
  cursor:zoom-in;
}
.galleryToolbar{
  position:absolute;
  left:14px;
  right:14px;
  bottom:14px;
  display:flex;
  justify-content:space-between;
  gap:10px;
  pointer-events:none;
}
.galleryBtn,
.galleryModal__nav,
.galleryModal__close{
  border:1px solid color-mix(in srgb, #fff 20%, var(--border));
  border-radius:999px;
  background:color-mix(in srgb, var(--surface) 86%, transparent);
  color:var(--text);
  box-shadow:var(--shadow);
  backdrop-filter:blur(14px);
  cursor:pointer;
}
.galleryBtn{
  width:44px;
  height:44px;
  pointer-events:auto;
  font-size:26px;
  line-height:1;
}
.galleryBtn--open{
  margin-left:auto;
  margin-right:auto;
  font-size:19px;
}
.thumb.is-active{
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--ring);
}
body.is-modal-open{
  overflow:hidden;
}
.galleryModal{
  position:fixed;
  inset:0;
  z-index:200;
  display:none;
  align-items:center;
  justify-content:center;
  padding:26px 74px;
  background:rgba(0,0,0,.88);
}
.galleryModal.is-open{
  display:flex;
}
.galleryModal__img{
  width:100%;
  height:100%;
  object-fit:contain;
}
.galleryModal__close{
  position:absolute;
  top:18px;
  right:18px;
  width:44px;
  height:44px;
  font-size:28px;
  color:#fff;
  background:rgba(20,20,22,.72);
}
.galleryModal__nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:52px;
  height:52px;
  font-size:34px;
  color:#fff;
  background:rgba(20,20,22,.72);
}
.galleryModal__nav--prev{ left:18px; }
.galleryModal__nav--next{ right:18px; }
.galleryModal__count{
  position:absolute;
  left:50%;
  bottom:20px;
  transform:translateX(-50%);
  padding:8px 14px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
  background:rgba(20,20,22,.72);
  color:#fff;
  font-weight:800;
}

@media (max-width:980px){
  .brand__logo{
    height:48px;
    max-width:min(64vw, 230px);
  }
  .themeBtn{
    width:64px;
    height:34px;
    top:12px;
  }
  .themeBtn__knob{
    width:26px;
    height:26px;
  }
  .themeBtn[aria-pressed="true"] .themeBtn__knob{
    transform:translateX(30px);
  }
  .contactGrid--wide{
    grid-template-columns:1fr;
  }
  .contactTree{
    position:static;
  }
}

@media (max-width:620px){
  .brand__logo{
    height:42px;
    max-width:min(62vw, 190px);
  }
  .themeBtn{
    width:58px;
    height:32px;
    top:5px;
  }
  .themeBtn__track{
    padding:0 8px;
  }
  .themeBtn__knob{
    width:24px;
    height:24px;
  }
  .themeBtn[aria-pressed="true"] .themeBtn__knob{
    transform:translateX(26px);
  }
  .hero__frame--page .hero__media{
    height:auto;
    aspect-ratio:16/9;
  }
  .detailFrame__mainImg{
    height:58vh;
    min-height:300px;
  }
  .galleryModal{
    padding:68px 12px 58px;
  }
  .galleryModal__nav{
    top:auto;
    bottom:16px;
    transform:none;
    width:46px;
    height:46px;
  }
  .galleryModal__nav--prev{ left:18px; }
  .galleryModal__nav--next{ right:18px; }
}

/* Theme-aware bubble controls and media alignment */
:root{
  --bubble-bg:rgba(255,255,255,.78);
  --bubble-hover:#ffffff;
  --bubble-text:#111214;
  --bubble-border:rgba(17,18,20,.14);
  --bubble-shadow:0 7px 22px rgba(17,24,39,.11), inset 0 1px 0 rgba(255,255,255,.92);
  --control-strong-bg:#111214;
  --control-strong-text:#ffffff;
  --control-strong-border:#111214;
}

html.dark{
  --bubble-bg:rgba(25,25,27,.82);
  --bubble-hover:#232326;
  --bubble-text:#f5f5f7;
  --bubble-border:rgba(255,255,255,.15);
  --bubble-shadow:0 9px 26px rgba(0,0,0,.38), inset 0 1px 0 rgba(255,255,255,.10);
  --control-strong-bg:#f5f5f7;
  --control-strong-text:#09090a;
  --control-strong-border:#f5f5f7;
}

.navPill{
  background:var(--bubble-bg);
  border-color:var(--bubble-border);
  box-shadow:var(--bubble-shadow);
  backdrop-filter:blur(22px) saturate(132%);
}
.navPill__item{
  transition:background .2s ease, color .2s ease, transform .2s ease;
}
.navPill__item:hover{
  color:var(--bubble-text);
  background:var(--bubble-hover);
}
.navPill__item.is-active{
  color:var(--control-strong-text);
  background:var(--control-strong-bg);
  box-shadow:0 5px 14px rgba(0,0,0,.16), inset 0 1px 0 rgba(255,255,255,.16);
}

.btn{
  border-color:var(--bubble-border);
  background:var(--bubble-bg);
  color:var(--bubble-text);
  box-shadow:var(--bubble-shadow);
  backdrop-filter:blur(20px) saturate(130%);
  transition:background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}
.btn:hover{
  border-color:var(--bubble-border);
  background:var(--bubble-hover);
  color:var(--bubble-text);
  transform:translateY(-1px);
  box-shadow:0 10px 26px rgba(0,0,0,.15), inset 0 1px 0 rgba(255,255,255,.82);
}
.btn--primary,
.btn--primary:hover{
  border-color:var(--control-strong-border);
  background:var(--control-strong-bg);
  color:var(--control-strong-text);
}

.hero__media{
  width:100%;
  height:auto;
  aspect-ratio:16 / 9;
  object-fit:contain;
  object-position:center;
  background:transparent;
}
video.hero__media{
  object-fit:cover;
  background:#000;
}
.hero__media--empty{
  min-height:0;
  aspect-ratio:16 / 9;
  background:var(--surface-alt);
}
.hero__frame--page .hero__media{
  height:auto;
  aspect-ratio:16 / 9;
}

.hero__nav,
.galleryBtn{
  border-color:var(--control-strong-border);
  background:var(--control-strong-bg);
  color:var(--control-strong-text);
  box-shadow:0 8px 22px rgba(0,0,0,.20), inset 0 1px 0 rgba(255,255,255,.18);
  backdrop-filter:blur(18px);
}
.hero__dots button.is-active,
.hero__progress span{
  background:var(--control-strong-bg);
}
.thumb.is-active{
  border-color:var(--control-strong-bg);
  box-shadow:0 0 0 3px color-mix(in srgb, var(--control-strong-bg) 20%, transparent);
}

.wideCard__shopLink{
  border-color:var(--bubble-border);
  background:var(--bubble-bg);
  color:var(--bubble-text);
  box-shadow:var(--bubble-shadow);
}

.themeBtn,
html.dark .themeBtn{
  width:62px;
  height:34px;
  padding:3px;
  border-color:var(--bubble-border);
  background:var(--bubble-bg);
  box-shadow:var(--bubble-shadow);
}
.themeBtn__track{
  width:54px;
  height:26px;
  flex:0 0 54px;
  padding:0 7px;
  background:transparent;
}
.themeBtn__sun,
.themeBtn__moon{
  width:11px;
  height:11px;
  color:var(--bubble-text);
}
.themeBtn__sun{
  width:10px;
  height:10px;
  background:currentColor;
  border:0;
  box-shadow:none;
}
.themeBtn__sun::before,
.themeBtn__sun::after{
  content:none;
}
.themeBtn__moon{
  background:transparent;
  box-shadow:-3px 0 0 currentColor;
}
.themeBtn__knob{
  left:1px;
  top:1px;
  width:24px;
  height:24px;
  background:var(--surface-alt);
  border-color:var(--bubble-border);
  box-shadow:0 4px 12px rgba(0,0,0,.14), inset 0 1px 0 color-mix(in srgb, var(--bubble-text) 9%, transparent);
}
.themeBtn[aria-pressed="true"] .themeBtn__knob{
  transform:translateX(28px);
}

.cardRow{
  align-items:stretch;
}
.cardGrid{
  align-items:stretch;
}
.card{
  align-items:stretch;
}
.card:not(.card--grid){
  align-items:center;
}
.card--grid{
  height:100%;
}
.card__thumb,
.card--grid .card__thumb{
  height:auto;
  aspect-ratio:4 / 3;
  padding:10px;
  place-items:center;
}
.card:not(.card--grid) .card__thumb{
  width:136px;
  height:102px;
  aspect-ratio:auto;
  flex:0 0 136px;
  align-self:center;
}
.card__thumb{
  position:relative;
}
.card__thumb img{
  position:absolute;
  inset:10px;
  width:calc(100% - 20px);
  height:calc(100% - 20px);
  max-width:calc(100% - 20px);
  max-height:calc(100% - 20px);
  display:block;
  object-fit:contain;
  object-position:center;
}
.projCard__thumb img,
.docCard__thumb img{
  display:block;
  width:100%;
  height:100%;
  margin:auto;
  object-fit:contain;
  object-position:center;
}
.card--grid .card__meta{
  flex:1;
}
.card--grid .card__meta .btn{
  margin-top:auto;
}
.projCard__thumb{
  height:auto;
  aspect-ratio:16 / 10;
  padding:10px;
}
.docCard__thumb{
  height:auto;
  aspect-ratio:4 / 3;
  padding:10px;
}

@media (max-width:980px){
  .themeBtn,
  html.dark .themeBtn{
    width:62px;
    height:34px;
    top:12px;
  }
  .themeBtn__knob{
    width:24px;
    height:24px;
  }
  .themeBtn[aria-pressed="true"] .themeBtn__knob{
    transform:translateX(28px);
  }
}

@media (max-width:620px){
  .themeBtn,
  html.dark .themeBtn{
    width:58px;
    height:32px;
    top:5px;
  }
  .themeBtn__track{
    width:50px;
    height:24px;
    flex-basis:50px;
    padding:0 6px;
  }
  .themeBtn__knob{
    width:22px;
    height:22px;
  }
  .themeBtn[aria-pressed="true"] .themeBtn__knob{
    transform:translateX(26px);
  }
  .card__thumb,
  .card--grid .card__thumb{
    width:100%;
    height:auto;
    aspect-ratio:4 / 3;
  }
}
