:root{
  /* ═══ Konvia Brand Palette ═══ */
  --konvia-dark-blue:#003b4f;
  --konvia-light-blue:#76acd4;
  --konvia-green:#0fa45c;
  --konvia-red:#e40327;
  --konvia-orange:#f49716;
  --konvia-mid-grey:#36454f;
  --konvia-dark-grey:#1b2a25;
  --konvia-silver:#f5f3f1;
  /* ═══ Theme Tokens ═══ */
  --bg:#fdfdfd;
  --bg-alt:#f5f3f1;
  --ink:#003b4f;
  --muted:#36454f;
  --text-strong:#003b4f;
  --text-body:#1b2a25;
  --text-soft:#36454f;
  --glass:#ffffff;
  --surface:#ffffff;
  --surface-strong:#f5f3f1;
  --outline:#003b4f;
  --accent:#003b4f;
  --accent-light:#76acd4;
  --accent-2:#002a39;
  --cta:#f49716;
  --cta-hover:#db8710;
  --cta-shadow:rgba(244,151,22,.35);
  --shadow:0 25px 65px rgba(0,59,79,.08);
  --blur:0px;
  --ctrl:#ffffff;
  --ctrl-border:#cfd6e4;
  --danger:#e40327;
  --success:#0fa45c;
  --speed:420ms;
  --button-bg:#003b4f;
  --button-border:#d9deea;
  --veil:rgba(245,243,241,.92);
  --panel:#ffffff;
  --panel-border:#dfe4ef;
  --panel-button-bg:#f5f3f1;
  --sup:#36454f;
  --logo-glow-start:rgba(0,59,79,.05);
  --logo-glow-end:rgba(0,59,79,.08);
  --logo-max:420px;
  --plexus-color:#003b4f;
  --plexus-line-color:#76acd4;
  --space-color:#f5f3f1;
  --space-fog:#ebe8e5;
  --font-family:"Barlow",Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{height:100%}
body{
  margin:0;
  font:16px/1.6 var(--font-family);
  background:linear-gradient(180deg,var(--bg),var(--bg-alt));
  color:var(--text-body,#003b4f);
  overflow:hidden;
  -webkit-font-smoothing:antialiased;
}
#bg{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.85}
#view{position:relative;z-index:1;width:100%;height:100%;display:flex;align-items:center;justify-content:center;perspective:1400px;overflow:hidden}
#stage{position:relative;width:100%;height:100%;transform-style:preserve-3d}
#vignette{pointer-events:none;position:fixed;inset:0;z-index:2;background:radial-gradient(70% 45% at 50% 0%,rgba(0,59,79,.12),transparent)}
#sceneFade{
  position:fixed;
  inset:0;
  z-index:5;
  background:radial-gradient(120% 120% at 50% 50%,rgba(255,255,255,.9),rgba(255,255,255,0.5) 45%,rgba(255,255,255,0));
  pointer-events:none;
  opacity:0;
  transition:none;
  mix-blend-mode:screen;
}
.page{
  position:absolute;top:50%;left:50%;
  width:min(94vw,1040px);
  background:transparent;
  border:1px solid transparent;
  border-radius:clamp(20px,3.5vw,28px);
  padding:clamp(22px,5vw,48px);
  box-shadow:none;
  transform:translate(-50%,-50%) scale(var(--s,1));
  transform-style:preserve-3d;
  filter:blur(var(--blur-amount,0px));
  opacity:0;
  color:var(--text-body,#003b4f);
  will-change:transform,opacity,filter;
  max-height:calc(100vh - 200px);
  max-height:calc(100dvh - clamp(100px,15vh,200px));
  overflow:auto;
  overscroll-behavior:contain;
  scrollbar-width:thin;
  scrollbar-color:var(--accent-light) transparent;
  scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;
}
.page::-webkit-scrollbar{width:8px}
.page::-webkit-scrollbar-track{background:rgba(0,59,79,.08);border-radius:999px}
.page::-webkit-scrollbar-thumb{background:var(--accent-light);border-radius:999px}
.page h1{margin:0 0 16px;font-size:clamp(26px,5.5vw,46px);line-height:1.15;font-weight:800;color:var(--text-strong,#003b4f);text-wrap:balance;text-shadow:0 1px 8px rgba(253,253,251,.95),0 2px 16px rgba(253,253,251,.8)}
.page h2{margin:clamp(24px,4vw,40px) 0 14px;font-size:clamp(21px,4vw,32px);line-height:1.25;font-weight:700;color:var(--text-strong,#003b4f);text-wrap:balance;text-shadow:0 1px 6px rgba(253,253,251,.9)}
.page h3{margin:clamp(16px,2.5vw,24px) 0 10px;font-size:clamp(17px,2.8vw,22px);line-height:1.35;font-weight:600;color:var(--text-strong,#003b4f);text-shadow:0 1px 5px rgba(253,253,251,.9)}
.page p{margin:10px 0 0;color:var(--text-body,#003b4f);font-size:clamp(15px,2.2vw,17px);line-height:1.65;text-shadow:0 1px 4px rgba(253,253,251,.85)}
.page .sup{letter-spacing:.22em;text-transform:uppercase;font-size:clamp(10.5px,1.6vw,12px);color:var(--accent-light)}
.page:not(.landing){
  -webkit-mask-image:linear-gradient(to bottom,transparent 0px,#000 40px,#000 calc(100% - 40px),transparent 100%);
  mask-image:linear-gradient(to bottom,transparent 0px,#000 40px,#000 calc(100% - 40px),transparent 100%);
}
.micro-note{
  margin:18px 0 0;
  font-size:14px;
  color:var(--text-soft,#003b4f);
  font-style:italic;
}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;margin-top:32px}
.option,.chip{
  border:1px solid var(--outline);
  border-radius:18px;
  background:transparent;
  color:inherit;
  text-align:left;
  padding:24px;
  transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease,background .2s ease;
  box-shadow:0 14px 30px rgba(0,59,79,.06);
}
.option::after{
  content:"";
  display:block;
  height:3px;
  width:48px;
  margin-top:18px;
  border-radius:999px;
  background:var(--accent-light);
  opacity:.45;
}
.option:hover,.chip:hover{border-color:var(--accent);background:rgba(0,59,79,.08);transform:translateY(-2px)}
.chip{display:inline-flex;align-items:center;gap:8px;font-weight:600;cursor:pointer;padding:12px 18px;border-radius:999px;box-shadow:none}
.chip.is-active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 10px 20px rgba(0,59,79,.2)}
.hero-block{display:flex;flex-direction:column;align-items:center;text-align:center;gap:20px}
.hero-logo{display:block;max-width:240px;margin:0 auto}
.hero-logo img{width:100%;height:auto}
.hero-claim{font-size:clamp(15px,2.4vw,18px);font-weight:600;color:var(--accent-light)}
.hero-ctas{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(10px,2vw,16px);margin-top:clamp(12px,2vw,16px)}
.hero-block .description{margin-top:22px;max-width:640px}
.persona-nav{
  display:flex;
  flex-wrap:wrap;
  gap:clamp(8px,1.5vw,12px);
  align-items:center;
  background:transparent;
  border:1px solid var(--outline);
  border-radius:clamp(14px,2.5vw,20px);
  padding:clamp(12px,2.5vw,18px) clamp(16px,3vw,24px);
  margin:8px 0 clamp(18px,3.5vw,32px);
}
.persona-nav strong{font-size:14px;color:var(--text-strong,#003b4f);}
.persona-chips{display:flex;flex-wrap:wrap;gap:8px}
.persona-chip{background:transparent;border:1px solid var(--outline);color:var(--text-strong,#003b4f);padding:10px 18px;border-radius:999px;font-weight:600;font-size:14px;cursor:pointer;transition:background .2s ease,color .2s ease,box-shadow .2s ease,border-color .2s ease}
.persona-chip.is-active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 10px 24px rgba(0,59,79,.25)}
.content-block{
  background:transparent;
  border:1px solid var(--outline);
  border-radius:clamp(16px,3vw,24px);
  padding:clamp(18px,4vw,32px);
  margin-top:clamp(14px,3vw,24px);
  box-shadow:0 20px 40px rgba(0,59,79,.08);
}
.content-block.lead{margin-top:0}
.content-columns{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:28px;margin-top:16px}
.content-list{list-style:none;padding:0;margin:16px 0 0;display:grid;gap:10px}
.content-list li{padding-left:20px;position:relative;color:var(--text-body,#003b4f)}
.content-list li::before{
  content:"";
  position:absolute;
  left:0;
  top:9px;
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--accent-light);
}
.funnel-steps{list-style:none;counter-reset:step;padding:0;margin:24px 0 0;display:grid;gap:18px}
.funnel-steps li{
  counter-increment:step;
  position:relative;
  padding-left:48px;
  min-height:42px;
}
.funnel-steps li::before{
  content:counter(step);
  position:absolute;
  left:0;
  top:0;
  width:34px;
  height:34px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--accent-light));
  color:#fff;
  font-weight:700;
  display:flex;
  align-items:center;
  justify-content:center;
}
.tile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:28px;margin-top:24px}
.tile{
  border:1px solid var(--outline);
  border-radius:clamp(18px,3.5vw,26px);
  padding:clamp(20px,4vw,32px);
  background:transparent;
  box-shadow:0 24px 48px rgba(0,59,79,.08);
  display:flex;
  flex-direction:column;
  gap:12px;
}
.tile h3{margin:0;font-size:clamp(20px,3.5vw,26px)}
.tile ul{list-style:none;padding:0;margin:8px 0 0;display:grid;gap:8px;color:var(--text-body,#003b4f)}
.tile ul li{padding-left:18px;position:relative}
.tile ul li::before{
  content:"";
  position:absolute;
  left:0;
  top:10px;
  width:6px;
  height:6px;
  border-radius:999px;
  background:var(--accent-light);
}
.faq-list{margin:32px 0 0;padding:0;list-style:none;display:grid;gap:16px}
.faq-item{
  border:1px solid var(--outline);
  border-radius:clamp(14px,2.5vw,20px);
  padding:clamp(14px,2.5vw,20px) clamp(16px,3vw,24px);
  background:transparent;
  box-shadow:0 18px 32px rgba(0,59,79,.07);
}
.faq-item strong{display:block;color:var(--text-strong,#003b4f);margin-bottom:6px}
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;margin-top:24px}
.form-shell{
  border:1px solid var(--outline);
  border-radius:clamp(16px,3vw,24px);
  padding:clamp(18px,3.5vw,28px);
  background:transparent;
  box-shadow:0 20px 36px rgba(0,59,79,.08);
  display:flex;
  flex-direction:column;
  gap:clamp(12px,2vw,16px);
}
.form-preface{
  margin:-8px 0 4px;
  font-size:15px;
  color:var(--text-soft,#003b4f);
}
.form-shell label{display:flex;flex-direction:column;gap:6px;font-weight:600;color:var(--text-strong,#003b4f)}
.form-shell input,
.form-shell textarea,
.form-shell select{
  border:1px solid var(--outline);
  border-radius:14px;
  padding:12px 14px;
  font:inherit;
  color:var(--text-body,#003b4f);
  background:var(--surface-strong);
  transition:border-color .2s ease,box-shadow .2s ease;
}
.form-shell input:focus,
.form-shell textarea:focus,
.form-shell select:focus{
  outline:none;
  border-color:var(--accent-light);
  box-shadow:0 0 0 3px rgba(118,172,212,.3);
}
.form-shell textarea{min-height:120px;resize:vertical}
.form-inline{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}
.checkbox-group{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin:8px 0 12px;
  border:none;
  padding:0;
}
.checkbox-group label{display:flex;align-items:center;gap:6px;font-weight:500;font-size:13px;margin:0;color:var(--text-soft,#003b4f)}
.checkbox-group input{width:16px;height:16px}
.consent{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:var(--text-soft,#003b4f)}
.form-context{font-size:14px;font-weight:600;color:var(--text-strong,#003b4f);margin:0}
.form-footnote{font-size:13px;color:var(--text-soft,#003b4f)}
.form-status{font-size:14px;font-weight:600;min-height:20px;color:var(--success)}
.form-status.is-error{color:var(--danger)}
.link-trigger{
  border:none;
  background:none;
  color:var(--accent-light);
  padding:0;
  font:inherit;
  text-decoration:underline;
  cursor:pointer;
}
.cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:clamp(11px,1.8vw,14px) clamp(20px,3.5vw,28px);
  border-radius:clamp(11px,1.8vw,14px);
  border:1px solid transparent;
  background:var(--cta);
  color:#fff;
  font-weight:700;
  font-size:clamp(13px,1.8vw,16px);
  letter-spacing:.04em;
  text-transform:uppercase;
  cursor:pointer;
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease;
  box-shadow:0 18px 40px var(--cta-shadow);
}
.cta:hover{transform:translateY(-2px);box-shadow:0 22px 44px var(--cta-shadow);background:var(--cta-hover)}
.cta:active{transform:translateY(0);box-shadow:0 12px 24px var(--cta-shadow)}
.cta:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(244,151,22,.35),0 18px 32px var(--cta-shadow)}
.cta--secondary{
  background:var(--cta);
  border-color:var(--cta);
  color:#fff;
  box-shadow:0 18px 36px var(--cta-shadow);
}
.cta--ghost{
  background:transparent;
  border:1px solid var(--cta);
  color:var(--cta);
  box-shadow:none;
}
.cta--ghost:hover{background:rgba(244,151,22,.1);box-shadow:none}
button{
  font:inherit;
  background:none;
  color:inherit;
  border:none;
  padding:0;
}
button:focus-visible,
a:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:3px;
}
.landing{
  background:transparent;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
  border:none;
  box-shadow:none;
  padding:0;
  filter:none;
  width:min(92vw,900px);
  min-height:calc(100vh - 180px);
  min-height:calc(100dvh - 180px);
  max-height:none;
  overflow:visible;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
}
.logo-tile{
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto;
  padding:0;
  width:100%;
  max-width:500px;
  border:none;
  background:none;
  border-radius:0;
  cursor:pointer;
  position:relative;
  overflow:visible;
  box-shadow:none;
}
.logo-tile picture{display:block;width:100%}
.logo-tile img{
  display:block;
  width:100%;
  height:auto;
  max-width:var(--logo-max);
  margin:0 auto;
  max-height:clamp(220px,calc(90vh - 240px),var(--logo-max));
  max-height:clamp(220px,calc(90dvh - 240px),var(--logo-max));
  object-fit:contain;
  filter:drop-shadow(0 20px 34px rgba(13,31,66,.15));
}
#backButton{
  position:fixed;
  left:32px;
  bottom:36px;
  z-index:8;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:0 28px;
  border-radius:999px;
  border:1px solid var(--button-border);
  background:var(--button-bg);
  color:#fff;
  font-size:15px;
  cursor:pointer;
  transition:opacity .4s ease,transform .4s ease,box-shadow .3s ease;
  box-shadow:0 18px 40px rgba(15,36,66,.15);
  min-width:190px;
  height:54px;
  flex-shrink:0;
  opacity:0;
  pointer-events:none;
  transform:translateY(18px);
}
#backButton.is-visible{
  opacity:1;
  pointer-events:auto;
  transform:translateY(0);
}
#backButton.is-visible[disabled]{opacity:.45;cursor:not-allowed}
#backButton .icon{font-size:14px;line-height:1;display:inline-flex;color:inherit}
#infoButton{
  position:fixed;
  right:32px;
  bottom:36px;
  width:56px;
  height:56px;
  border-radius:50%;
  border:1px solid var(--button-border);
  background:var(--button-bg);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:0 18px 40px rgba(15,36,66,.15);
  z-index:8;
  transition:transform .3s;
}
#infoButton:hover{transform:translateY(-4px)}
#infoButton svg{width:22px;height:22px;fill:#fff}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
#infoPanel{
  position:fixed;
  inset:0;
  z-index:4;
  background:var(--veil);
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  pointer-events:none;
  transition:opacity .35s ease;
}
#infoPanel.is-open{opacity:1;pointer-events:auto}
.info-shell{
  width:min(720px,92vw);
  max-height:80vh;
  max-height:80dvh;
  background:var(--panel);
  border:1px solid var(--panel-border);
  border-radius:clamp(20px,4vw,30px);
  padding:clamp(20px,4.5vw,36px);
  box-shadow:0 40px 90px rgba(15,36,66,.18);
  display:flex;
  flex-direction:column;
  gap:clamp(12px,2vw,18px);
}
.info-shell header{display:flex;justify-content:space-between;align-items:center;gap:12px}
.info-shell h2{margin:0;font-size:clamp(20px,3.5vw,26px);color:var(--text-strong,#003b4f)}
.close-info{
  border:1px solid var(--button-border);
  border-radius:999px;
  padding:8px 16px;
  text-transform:uppercase;
  letter-spacing:.2em;
  font-size:11px;
  cursor:pointer;
  background:var(--panel-button-bg);
}
.info-content{
  overflow:auto;
  padding-right:12px;
  color:var(--muted,#003b4f);
  font-size:15px;
  line-height:1.6;
}
.info-content::-webkit-scrollbar{width:6px}
.info-content::-webkit-scrollbar-track{background:rgba(0,59,79,.08);border-radius:999px}
.info-content::-webkit-scrollbar-thumb{background:var(--accent-light);border-radius:999px}
.info-content h3{margin:18px 0 8px;font-size:18px;color:var(--text-strong,#003b4f)}
.info-content p{margin:0 0 14px}
.info-content strong{color:var(--text-strong,#003b4f)}

/* ═══ Responsive: Tablet ═══ */
@media(max-width:900px){
  .page{padding:36px;border-radius:24px}
}

/* ═══ Responsive: Small Tablet / Large Phone ═══ */
@media(max-width:720px){
  .page{
    padding:28px 22px;
    max-height:calc(100dvh - 140px);
    border-radius:22px;
  }
  .page:not(.landing){
    -webkit-mask-image:linear-gradient(to bottom,transparent 0px,#000 28px,#000 calc(100% - 28px),transparent 100%);
    mask-image:linear-gradient(to bottom,transparent 0px,#000 28px,#000 calc(100% - 28px),transparent 100%);
  }
  #backButton{bottom:20px;left:20px;min-width:160px;height:48px;font-size:14px;padding:0 22px}
  #infoButton{bottom:20px;right:20px;width:48px;height:48px}
  #infoButton svg{width:18px;height:18px}
  .persona-nav{flex-direction:column;align-items:flex-start;padding:14px 18px;gap:10px}
  .content-block{padding:24px;border-radius:20px;margin-top:18px}
  .content-block.lead{margin-top:0}
  .tile{padding:24px;border-radius:22px}
  .faq-item{padding:16px 20px;border-radius:16px}
  .form-shell{padding:22px;border-radius:20px}
  .info-shell{padding:28px;border-radius:24px}
  .info-shell h2{font-size:22px}
  .hero-block{gap:16px}
  .hero-block .description{margin-top:14px}
}

/* ═══ Responsive: Phone ═══ */
@media(max-width:540px){
  .page{
    padding:24px 18px;
    border-radius:20px;
    max-height:calc(100dvh - 100px);
  }
  .page:not(.landing){
    -webkit-mask-image:linear-gradient(to bottom,transparent 0px,#000 20px,#000 calc(100% - 20px),transparent 100%);
    mask-image:linear-gradient(to bottom,transparent 0px,#000 20px,#000 calc(100% - 20px),transparent 100%);
  }
  .grid{grid-template-columns:1fr}
  .content-columns,
  .tile-grid,
  .form-grid{grid-template-columns:1fr}
  .persona-chips{width:100%}
  .hero-ctas{flex-direction:column;align-items:stretch;width:100%;max-width:320px;margin-left:auto;margin-right:auto}
  .hero-ctas .cta{width:100%;justify-content:center}
  .content-block{padding:20px 18px;border-radius:18px;margin-top:14px}
  .tile{padding:22px 18px;border-radius:20px}
  .faq-item{padding:14px 16px;border-radius:14px}
  .faq-list{gap:12px}
  .form-shell{padding:20px 18px;border-radius:18px}
  .form-inline{grid-template-columns:1fr}
  .cta{padding:12px 22px;font-size:14px;border-radius:12px;letter-spacing:.03em}
  .cta--ghost{padding:11px 22px}
  .funnel-steps li{padding-left:40px}
  .funnel-steps li::before{width:30px;height:30px;font-size:13px}
  .content-list li{font-size:15px}
  #backButton{min-width:140px;height:44px;font-size:13px;padding:0 18px}
  #infoButton{width:44px;height:44px}
  .info-shell{padding:22px 20px;border-radius:20px;max-height:85vh}
  .info-shell h2{font-size:20px}
  .close-info{padding:6px 12px;font-size:10px}
  .micro-note{font-size:13px}
  .hero-block{gap:14px}
  .hero-block .description{margin-top:10px}
  .checkbox-group{gap:10px}
  .consent{font-size:12px}
  .form-footnote{font-size:12px}
}

/* ═══ Responsive: Small Phone ═══ */
@media(max-width:390px){
  .page{padding:20px 16px}
  .content-block{padding:16px 14px}
  .tile{padding:18px 16px}
  .form-shell{padding:18px 14px}
  .cta{padding:11px 18px;font-size:13px}
  #backButton{min-width:120px;height:42px;font-size:12px;padding:0 14px;left:12px;bottom:14px}
  #infoButton{width:42px;height:42px;right:12px;bottom:14px}
  .hero-ctas{max-width:280px}
  .info-shell{padding:18px 16px;border-radius:18px}
}

/* ─── Landing: Canvas Logo ─── */
.logo-tile canvas{
  display:block;
  max-width:100%;
  max-height:clamp(220px,calc(90dvh - 240px),var(--logo-max));
  cursor:pointer;
  animation:logoGlow 3.2s ease-in-out 2.2s infinite;
}
@keyframes logoGlow{
  0%,100%{filter:drop-shadow(0 0 0px transparent)}
  50%{filter:drop-shadow(0 0 18px rgba(118,172,212,.3))}
}

/* ─── Landing: Hint Text ─── */
.logo-hint{
  position:absolute;
  bottom:-38px;
  left:50%;
  transform:translateX(-50%) translateY(5px);
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--accent-light);
  opacity:0;
  pointer-events:none;
  white-space:nowrap;
  font-weight:500;
  animation:hintAppear 1s ease 2s forwards, hintBreathe 3s ease-in-out 3s infinite;
}
@keyframes hintAppear{
  0%{opacity:0;transform:translateX(-50%) translateY(5px)}
  100%{opacity:.55;transform:translateX(-50%) translateY(0)}
}
@keyframes hintBreathe{
  0%,100%{opacity:.55}
  50%{opacity:.25}
}

/* ─── Reduced Motion ─── */
@media(prefers-reduced-motion:reduce){
  .logo-hint{animation:none;opacity:.45;transform:translateX(-50%) translateY(0)}
  .logo-tile canvas{animation:none}
}

/* ─── Mobile Responsive: Landing ─── */
@media(max-width:720px){
  .landing{min-height:calc(100dvh - 120px)}
  .logo-tile{max-width:min(380px,72vw)}
  .logo-hint{bottom:-32px;font-size:11px}
}

@media(max-width:540px){
  .landing{min-height:calc(100dvh - 80px)}
  .logo-tile{max-width:min(280px,68vw)}
  .logo-hint{bottom:-26px;font-size:10.5px;letter-spacing:.18em}
}

@media(max-width:390px){
  .logo-tile{max-width:min(240px,65vw)}
  .logo-hint{bottom:-22px;font-size:10px;letter-spacing:.15em}
}

/* ─── Landscape / short viewports ─── */
@media(max-height:500px){
  .landing{min-height:calc(100dvh - 60px)}
  .logo-tile{max-width:min(220px,50vw)}
  .logo-tile canvas{
    max-height:clamp(100px,calc(75dvh - 60px),240px);
  }
  .logo-hint{bottom:-18px;font-size:9.5px;letter-spacing:.14em}
}

@media(max-height:400px) and (max-width:900px){
  .logo-tile{max-width:min(180px,45vw)}
  .logo-hint{bottom:-16px;font-size:9px}
}
