a{color:inherit;text-decoration:none}
.btn-dk{background:var(--dark);color:var(--text-on-dark);border:1px solid var(--border-light);display:inline-flex;align-items:center;gap:8px;padding:10px 22px;border-radius:8px;font-size:13px;font-weight:600;letter-spacing:.2px;transition:all .25s;cursor:pointer;font-family:var(--font);text-decoration:none}
.btn-dk:hover{background:var(--dark2)}

/* ═══ HERO ═══ */
.hero-section{position:relative;overflow:hidden;display:flex;flex-direction:row;border-bottom:1px solid rgba(0,0,0,.08);background:#FAF8F0}
.hero-left{flex:1 0 0;max-width:720px;min-height:100vh;display:flex;flex-direction:column;justify-content:space-between;align-items:flex-start;padding:50px 0 40px;position:relative;z-index:2}
.hero-content{display:flex;flex-direction:column;gap:48px;padding:0 20px 48px 56px;width:100%}
.hero-text{display:flex;flex-direction:column;gap:28px;width:100%}
.hero-left h1{font-size:clamp(40px,4.5vw,64px);font-weight:700;line-height:1em;letter-spacing:-.02em;color:#2B2A29;margin:0}
.hero-left h1 em{font-family:var(--serif);font-style:italic;font-weight:400;position:relative;display:inline-block;padding:0 8px;color:#041314}
.hero-left h1 em::before{content:'';position:absolute;top:0;left:0;width:85%;height:92%;background:var(--teal)}
.hero-left h1 em::after{content:'';position:absolute;right:0;bottom:0;width:85%;height:92%;background:var(--teal)}
.hero-left h1 em span{position:relative;z-index:1}
.hero-sub{font-size:17px;color:rgba(0,0,0,.6);line-height:1.7em;max-width:500px}

/* Chat input */
.chat-wrap{display:flex;flex-direction:column;width:100%}
.chat{position:relative;background:rgba(0,0,0,.03);border:1px solid rgba(0,0,0,.1);border-right:0;display:flex;align-items:center;gap:20px;padding:0 20px 0 0;transition:background .3s}
.chat:focus-within{background:rgba(0,0,0,.05)}
.chat input{flex:1;background:none;border:none;color:#2B2A29;font-size:20px;font-family:var(--font);outline:none;padding:30px 0 30px 56px;caret-color:transparent}
.chat .placeholder-anim{position:absolute;left:56px;top:50%;transform:translateY(-50%);display:flex;align-items:center;pointer-events:none;gap:2px;transition:opacity .2s}
.chat .placeholder-anim span{background:linear-gradient(90deg,rgba(0,0,0,.35) 0%,rgba(0,0,0,.35) 30%,rgba(0,0,0,.65) 50%,rgba(0,0,0,.35) 70%,rgba(0,0,0,.35) 100%);background-size:300% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-family:var(--font);font-size:20px;font-weight:400;animation:shimmer 3s infinite linear}
@keyframes shimmer{0%{background-position:100% 50%}100%{background-position:-100% 50%}}
.chat .teal-cursor{width:3px;height:24px;background:var(--teal);animation:blink 1s step-end infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.chat button{width:52px;height:40px;border-radius:50px;background:#2B2A29;border:none;color:#FAF8F0;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity .2s}
.chat button:hover{opacity:.85}
.chat.loading button{opacity:.4;pointer-events:none}
.chat .teal-line{position:absolute;bottom:0;left:0;width:100%;height:1px;background:var(--teal);z-index:1}

/* Suggested prompts */
.suggested{display:flex;flex-direction:column;width:100%}
.suggested a{height:75px;display:flex;align-items:center;gap:10px;padding:0 20px 0 56px;font-size:18px;color:rgba(0,0,0,.5);border-bottom:1px solid rgba(0,0,0,.06);transition:color .2s,background .2s;text-decoration:none}
.suggested a:first-child{border-top:none}
.suggested a:hover{color:var(--teal);background:rgba(0,201,167,.04)}
.suggested a .s-icon{flex-shrink:0;width:20px;height:20px;opacity:.5}
.suggested a:hover .s-icon{opacity:1}

/* Trust bar */
.trust{padding:16px 56px 0;display:flex;flex-direction:column;gap:32px;width:100%}
.trust-label{font-size:13px;font-weight:500;color:rgba(0,0,0,.3)}
.trust-logos{display:flex;gap:30px;align-items:center;max-width:500px;justify-content:space-between}
.trust-logos span{font-family:var(--mono);font-size:13px;font-weight:600;color:rgba(0,0,0,.2)}

/* Hero right — character field */
.hero-right{flex:1 0 0;border-left:1px solid rgba(0,0,0,.06);position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#FAF8F0}
.hero-right canvas{display:block;width:100%;height:100%;position:absolute;top:0;left:0}

/* Chat overlay on right panel */
.chat-overlay{
  position:absolute;inset:0;z-index:2;
  background:rgba(250,248,240,.88);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  display:flex;flex-direction:column;
  opacity:0;transition:opacity .4s ease;pointer-events:none;
}
.chat-overlay.active{opacity:1;pointer-events:auto}
.chat-overlay-inner{
  flex:1;display:flex;flex-direction:column;
  padding:20px 48px 40px;overflow-y:auto;
}
.chat-overlay-question{
  display:flex;align-items:center;justify-content:space-between;
  font-size:14px;color:var(--teal);font-weight:600;
  background:#fff;border:1px solid rgba(0,201,167,.25);
  padding:10px 20px;border-radius:100px;margin-bottom:24px;
  font-style:normal;line-height:1.4;
}
.chat-q-close{
  background:none;border:none;color:var(--teal);font-size:18px;cursor:pointer;
  width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  transition:all .2s;flex-shrink:0;line-height:1;
}
.chat-q-close:hover{background:rgba(0,201,167,.12)}
/* Markdown rendering inside chat */
.chat-md p{margin:0 0 16px;line-height:1.75}
.chat-md p:last-child{margin-bottom:0}
.chat-md strong{font-weight:700;color:#2B2A29}
.chat-md em{font-style:italic}
.chat-md code{font-family:var(--mono);font-size:.85em;background:rgba(0,0,0,.05);padding:2px 6px;border-radius:4px;color:#2B2A29}
/* Butler window chrome — matches Design System */
.chat-md .bw{background:#F5F0E8;border-radius:16px;padding:12px;margin:14px 0}
.chat-md .bw-in{background:#fff;border-radius:12px;border:1.5px solid #E3DFD8;overflow:hidden}
.chat-md .bw-bar{background:#FBF9F6;border-bottom:1.5px solid #E3DFD8;padding:8px 14px;display:flex;align-items:center;gap:8px}
.chat-md .bw-dots{display:flex;gap:5px}
.chat-md .bw-dots i{width:9px;height:9px;border-radius:50%;background:#E3DFD8;display:block}
.chat-md .bw-lbl{font-family:var(--mono);font-size:11px;color:#8b7d6b;letter-spacing:.5px;flex:1}
.chat-md .bw-ind{width:7px;height:7px;border-radius:50%;background:var(--teal);animation:dotPulse 2s infinite}
.chat-md .bw-body{padding:12px 14px}
@keyframes dotPulse{0%,100%{opacity:1}50%{opacity:.4}}
.chat-md .bw pre{background:none;border-radius:0;padding:0;margin:0;overflow-x:auto}
.chat-md .bw pre code{background:none;padding:0;font-size:12px;line-height:1.6;display:block}
.chat-md .bw table{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:11px}
.chat-md .bw th{font-size:10px;font-weight:600;color:#8b7d6b;text-transform:uppercase;letter-spacing:.5px;padding:6px 10px;text-align:left;border-bottom:1.5px solid #E3DFD8}
.chat-md .bw td{padding:6px 10px;color:#3d3529;border-bottom:1px solid #f0eeeb}
.chat-md .bw tr:last-child td{border-bottom:none}
/* Legacy pre fallback (outside windows) */
.chat-md pre{background:rgba(0,0,0,.05);border-radius:8px;padding:14px 16px;margin:12px 0;overflow-x:auto}
.chat-md pre code{background:none;padding:0;font-size:13px;line-height:1.6;display:block}
.chat-md ul,.chat-md ol{margin:12px 0 16px;padding-left:24px}
.chat-md li{margin-bottom:6px;line-height:1.7}
.chat-md li::marker{color:var(--teal)}
.chat-md h1,.chat-md h2,.chat-md h3{font-weight:700;color:#2B2A29;margin:16px 0 8px;line-height:1.3}
.chat-md h1{font-size:20px}.chat-md h2{font-size:17px}.chat-md h3{font-size:15px}
.chat-md a{color:var(--teal);text-decoration:underline;text-underline-offset:2px}
.chat-md blockquote{border-left:3px solid var(--teal);padding-left:14px;margin:12px 0;color:rgba(0,0,0,.55);font-style:italic}
.chat-md hr{border:none;height:1px;background:rgba(0,0,0,.08);margin:16px 0}
/* Diffusion effect — slight opacity pulsing during refinement */
.chat-diffusing{animation:diffuse-pulse .6s ease-in-out infinite alternate}
@keyframes diffuse-pulse{from{opacity:.85}to{opacity:1}}

.chat-overlay-body{
  font-size:16px;color:rgba(0,0,0,.7);line-height:1.8;
  white-space:pre-wrap;padding:8px 18px 12px;
}
#rememberCheck:checked ~ #rememberTrack{background:var(--teal)}
#rememberCheck:checked ~ #rememberKnob{transform:translateX(16px)}
.chat-typing{display:inline-flex;gap:4px;padding:4px 0}
.chat-typing span{width:6px;height:6px;background:var(--teal);border-radius:50%;animation:td 1.2s infinite;opacity:.3}
.chat-typing span:nth-child(2){animation-delay:.2s}
.chat-typing span:nth-child(3){animation-delay:.4s}
@keyframes td{0%,100%{opacity:.3;transform:translateY(0)}50%{opacity:1;transform:translateY(-4px)}}

/* Mobile: chat response inline */
.chat-response-m{
  background:rgba(0,0,0,.02);border-left:1px solid rgba(0,0,0,.08);border-bottom:1px solid rgba(0,0,0,.08);
  overflow:hidden;animation:chatSlideIn .3s ease;display:none;
}
.chat-response-m.active{display:block}
@keyframes chatSlideIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.chat-response-m-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px 12px 56px;border-bottom:1px solid rgba(0,0,0,.06)}
.chat-response-m-label{font-family:var(--mono);font-size:12px;color:var(--teal);font-weight:600}
.chat-response-m-close{background:none;border:none;color:rgba(0,0,0,.3);font-size:20px;cursor:pointer;padding:0 4px;line-height:1}
.chat-response-m-close:hover{color:#2B2A29}
.chat-response-m-question{padding:12px 20px 0 56px}
.chat-response-m-question:empty{display:none}
.chat-response-m-question span{display:inline-block;font-size:13px;color:var(--teal);font-weight:600;background:#fff;border:1px solid rgba(0,201,167,.25);padding:8px 16px;border-radius:100px;line-height:1.4}
.chat-response-m-body{padding:16px 20px 16px 56px;font-size:15px;color:rgba(0,0,0,.6);line-height:1.7;max-height:260px;overflow-y:auto;white-space:pre-wrap}

/* SVG container */
.svg-wrap{width:100%;border-radius:16px;overflow:hidden;border:1px solid var(--border-light);box-shadow:0 8px 40px rgba(0,0,0,.06)}
.svg-wrap svg{display:block;width:100%}

/* GIF container */
.gif-wrap{border-radius:16px;overflow:hidden;border:1px solid var(--border-light);box-shadow:0 8px 40px rgba(0,0,0,.06)}
.gif-wrap img{display:block;width:100%;height:auto}

/* Split layout */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split.flip{direction:rtl}.split.flip>*{direction:ltr}

/* Stats bar — Glorics house style */
.stats-bar{
  background:var(--light2);border-top:1px solid var(--border-light);
  border-bottom:1px solid var(--border-light);
  display:flex;justify-content:center;flex-wrap:wrap;gap:0;
}
.stat-item{padding:32px 56px;text-align:center;border-right:1px solid var(--border-light)}
.stat-item:last-child{border-right:none}
.stat-num{font-family:var(--mono);font-size:34px;font-weight:700;letter-spacing:-1.5px;color:var(--text-on-light);line-height:1}
.stat-num.teal{color:var(--teal)}
.stat-lbl{font-family:var(--mono);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--subtle-on-light);margin-top:6px}

/* Dark stats override for teal class */
.dark-stat-num.teal{color:var(--teal)}

/* Steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:60px}
.step-n{font-family:var(--mono);font-size:12px;color:var(--teal);letter-spacing:1px;margin-bottom:12px}
.step h4{font-size:18px;font-weight:600;margin-bottom:8px}
.step p{font-size:14px;color:var(--muted-on-light);line-height:1.65}

/* Arch cards */
.ag{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:48px}
.ac{border:1px solid var(--border-light);border-radius:var(--rl);padding:36px;background:#fff;transition:all .3s}
.ac:hover{border-color:var(--teal);box-shadow:0 12px 40px rgba(0,0,0,.06)}
.ac-b{font-family:var(--mono);font-size:11px;padding:4px 14px;border-radius:20px;display:inline-block;margin-bottom:16px}
.ac-b-t{background:var(--teal-dim);color:#00a88c}
.ac-b-g{background:rgba(0,0,0,.05);color:var(--muted-on-light)}
.ac h3{font-size:18px;font-weight:600;margin-bottom:8px}
.ac p{font-size:14px;color:var(--muted-on-light);line-height:1.6;margin-bottom:20px}
.ac-tags{display:flex;flex-wrap:wrap;gap:6px}
.ac-tags span{font-family:var(--mono);font-size:11px;padding:4px 10px;border-radius:6px;border:1px solid var(--border-light);color:var(--muted-on-light)}

/* Table */
/* Scrollable wrappers */
.ctbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-top:48px;border-radius:var(--r);border:1px solid var(--border-light)}
.jsx-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}
.ctbl{width:100%;border-collapse:collapse;font-size:14px;min-width:600px}
.ctbl th{text-align:left;font-weight:600;padding:12px 16px;border-bottom:2px solid var(--border-light)}
.ctbl td{padding:12px 16px;border-bottom:1px solid var(--border-light);color:var(--muted-on-light)}
.ctbl td:first-child{font-weight:500;color:var(--text-on-light)}

/* Product sections */
.pt h2{font-size:clamp(28px,3.5vw,44px);font-weight:700;line-height:1.12;letter-spacing:-1px;margin-bottom:16px;color:var(--text-on-light)}
.pt h2 em{font-family:var(--serif);font-style:italic;color:var(--teal);font-weight:400}
.pt p{font-size:16px;color:var(--muted-on-light);line-height:1.7;margin-bottom:24px}
.pt .note{font-size:14px;color:var(--subtle-on-light);font-style:italic}

/* Terminal */
.term{background:#0a0a0e;border:1px solid var(--border-dark2);border-radius:var(--r);overflow:hidden;font-family:var(--mono);font-size:13px;line-height:1.8}
.term-bar{height:36px;background:var(--dark3);border-bottom:1px solid var(--border-dark);display:flex;align-items:center;padding:0 14px;gap:8px}
.dot{width:10px;height:10px;border-radius:50%}.dr{background:#ff5f57}.dy{background:#ffbd2e}.dg{background:#28ca41}
.term-body{padding:20px;color:var(--muted-on-dark);white-space:pre;overflow-x:auto}
.tc{color:var(--teal)}.tg{color:var(--gold)}.tok{color:#28ca41}.td{color:var(--subtle-on-dark)}

/* Cases */
.cases{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.cc{border:1px solid var(--border-light);border-radius:var(--rl);padding:32px;background:#fff;transition:all .3s}
.cc:hover{border-color:var(--teal);transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.06)}
.cc-l{font-family:var(--mono);font-size:11px;color:var(--teal);letter-spacing:.5px;margin-bottom:12px}
.cc h4{font-size:16px;font-weight:600;margin-bottom:8px;color:var(--text-on-light)}
.cc p{font-size:14px;color:var(--muted-on-light);line-height:1.6}

/* Memory cards (dark section) */
.memory-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:48px}
.mem-card{background:rgba(255,255,255,.04);border:1px solid var(--border-dark2);border-radius:var(--rl);padding:36px;transition:all .3s}
.mem-card:hover{border-color:var(--teal);background:rgba(255,255,255,.06)}
.mem-level{font-family:var(--mono);font-size:11px;color:var(--teal);letter-spacing:1px;text-transform:uppercase;margin-bottom:12px}
.mem-card h4{font-size:18px;font-weight:600;margin-bottom:8px;color:var(--text-on-dark)}
.mem-card p{font-size:14px;color:var(--muted-on-dark);line-height:1.65}

/* Step highlight (L4 teal) */
.step-hl{background:var(--teal-dim);border:1px solid var(--teal);border-radius:var(--rl);padding:24px}
.step-hl .step-n{color:var(--teal)}
.step-hl h4{color:var(--teal)}

/* Soul concepts — 2×2 grid */
.soul-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:48px}
.soul-concept{border:1px solid var(--border-light);border-radius:var(--rl);padding:32px;background:#fff;transition:all .3s}
.soul-concept:hover{border-color:var(--teal);box-shadow:0 12px 40px rgba(0,0,0,.06)}
.soul-concept h4{font-size:16px;font-weight:600;color:var(--text-on-light);margin-bottom:8px}
.soul-concept h4::before{content:'→ ';color:var(--teal);font-family:var(--mono)}
.soul-concept p{font-size:14px;color:var(--muted-on-light);line-height:1.65;margin:0}

/* Data/chart wrapper */
.dw{margin-top:48px;border-radius:var(--rl);overflow:hidden;border:1px solid var(--border-light);box-shadow:0 8px 40px rgba(0,0,0,.06)}
.dw img{display:block;width:100%;height:auto}

/* Question cards */
.questions-stack{display:flex;flex-direction:column;gap:20px;margin-top:48px;max-width:800px;margin-left:auto;margin-right:auto}
.q-card{border:1px solid var(--border-light);border-radius:var(--rl);padding:36px 40px;background:#fff;transition:all .3s;display:flex;gap:28px;align-items:flex-start}
.q-card:hover{border-color:var(--teal);box-shadow:0 12px 40px rgba(0,0,0,.06)}
.q-num{font-family:var(--mono);font-size:28px;font-weight:700;color:var(--teal);flex-shrink:0;line-height:1;min-width:40px}
.q-card h3{font-size:18px;font-weight:600;margin-bottom:8px;color:var(--text-on-light)}
.q-card p{font-size:14px;color:var(--muted-on-light);line-height:1.65}

/* Contact */
.cta-box{background:#fff;border:1px solid var(--border-light);border-radius:var(--rl);padding:48px;max-width:700px;margin:0 auto;text-align:center;box-shadow:0 8px 40px rgba(0,0,0,.04)}
.cta-box h2{font-size:clamp(28px,3vw,40px);font-weight:700;letter-spacing:-1px;margin-bottom:12px;color:var(--text-on-light)}
.cta-box p{color:var(--muted-on-light);margin-bottom:32px;font-size:16px}


/* Responsive */
@media(max-width:1024px){
  /* Hero: canvas on top, then chat, then title — all stacked */
  .hero-section{flex-direction:column}
  .hero-right{order:-1;width:100%;flex:none;height:45vh;min-height:220px;border-left:none;border-bottom:1px solid rgba(0,0,0,.06)}
  .hero-left{max-width:100%;min-height:auto;padding:clamp(16px,4vw,32px) 0 clamp(16px,3vw,24px)}
  .hero-content{padding:0 clamp(20px,5vw,40px);flex-direction:column;gap:clamp(16px,3vw,24px);align-items:stretch}
  .chat-wrap{order:-1}
  .hero-text{width:100%}
  .chat-wrap{width:100%}
  .hero-left h1{font-size:clamp(22px,5vw,40px)}
  .hero-sub{font-size:clamp(13px,2.5vw,16px);line-height:1.6}
  .chat input{font-size:clamp(14px,3vw,18px);padding:clamp(20px,4vw,30px) 0 clamp(20px,4vw,30px) clamp(20px,4vw,28px)}
  .chat .placeholder-anim{left:clamp(20px,4vw,28px)}
  .chat .placeholder-anim span{font-size:clamp(14px,3vw,18px)}
  .chat button{width:clamp(40px,8vw,52px);height:clamp(32px,6vw,40px)}
  .suggested a{padding-left:clamp(20px,4vw,28px);font-size:clamp(12px,2.5vw,15px);height:clamp(44px,9vw,56px)}
  .suggested a .s-icon{width:clamp(16px,3vw,20px);height:clamp(16px,3vw,20px)}
  .chat-overlay-inner{padding:clamp(20px,4vw,32px)}
  .split,.ag{grid-template-columns:1fr;gap:32px}.split.flip{direction:ltr}
  .memory-cards{grid-template-columns:1fr}
  .soul-grid{grid-template-columns:1fr}
  .steps[style*="repeat(4"]{grid-template-columns:1fr 1fr !important}
  .q-card{flex-direction:column;gap:12px;padding:clamp(24px,4vw,36px)}
  .q-num{font-size:22px}
  .split>*,.ag>*{max-width:100%}
  .jsx-wrap{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;max-width:100%;border-radius:12px}
  .pt h2{font-size:clamp(22px,5vw,36px)}
  .pt p{font-size:clamp(14px,3vw,16px)}
  .ac-tags{flex-wrap:wrap}
  .ac-tags span{font-size:10px;padding:3px 8px}
  .ac h3{font-size:clamp(15px,3vw,18px)}
  .ac p{font-size:clamp(12px,2.5vw,14px)}
  .stats-bar{display:grid;grid-template-columns:1fr 1fr 1fr}
  .stat-item{padding:12px 10px;border-right:none;border-bottom:1px solid var(--border-light)}
  .stat-item:nth-child(3n+1),.stat-item:nth-child(3n+2){border-right:1px solid var(--border-light)}
  .stat-item:nth-child(n+4){border-bottom:none}
  .stat-item:last-child{grid-column:auto}
  .steps,.cases{grid-template-columns:1fr}
  .stat-num{font-size:16px;letter-spacing:-0.5px}
  .stat-lbl{font-size:8px;letter-spacing:1px}
  .dark-stats{gap:clamp(16px,4vw,32px);padding-top:clamp(24px,5vw,48px);margin-top:clamp(32px,6vw,60px)}
  .dark-stat-num{font-size:clamp(24px,5vw,38px)}
  /* Cards & cases */
  .cases{gap:clamp(16px,3vw,24px)}
  .cc{padding:clamp(20px,4vw,32px)}
  .cc h4{font-size:clamp(14px,3vw,16px)}
  .cc p{font-size:clamp(12px,2.5vw,14px)}
  .ac{padding:clamp(24px,4vw,36px)}
  /* Contact */
  .cta-box{padding:clamp(28px,5vw,48px)}
  .section-center{margin-bottom:clamp(32px,6vw,56px)}
  /* Terminal */
  .term{font-size:clamp(10px,2vw,13px)}
  .term-body{padding:clamp(12px,3vw,20px);overflow-x:auto}
}
