/* ========== LOCAL WEB SA — Shared Styles ========== */
:root{
  --brand-blue:#0011FF;
  --brand-blue-deep:#0007A8;
  --brand-blue-mid:#0024F2;
  --accent-cyan:#00E5FF;
  --whatsapp-green:#00E676;
  --bg-black:#0A0A0A;
  --bg-black-2:#07070B;
  --surface-card:#15151A;
  --surface-card-2:#1B1B22;
  --text-grey:#B8B8C0;
  --text-grey-soft:#8A8A93;
  --white:#FFFFFF;
  --hairline:rgba(255,255,255,0.06);
  --hairline-strong:rgba(255,255,255,0.12);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0;background:var(--bg-black);color:var(--white);scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:16px;line-height:1.6;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* ====== LAYOUT ====== */
.wrap{max-width:1240px;margin:0 auto;padding:0 28px;width:100%}
.wrap-narrow{max-width:880px;margin:0 auto;padding:0 28px;width:100%}
section{padding:96px 0;position:relative;overflow:hidden}
section.blue{background:linear-gradient(180deg,var(--brand-blue-deep) 0%,var(--brand-blue) 50%,var(--brand-blue-mid) 100%);color:#fff}
section.black{background:var(--bg-black)}
section.tight{padding:64px 0}

.eyebrow{
  display:inline-block;
  font-size:12px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--accent-cyan);
}
section.black .eyebrow{color:var(--brand-blue);color:#3D52FF}
.h1{
  font-size:clamp(40px,5.5vw,72px);font-weight:800;line-height:1.04;letter-spacing:-0.025em;
  margin:0;color:#fff;
}
.h2{
  font-size:clamp(30px,3.6vw,46px);font-weight:700;letter-spacing:-0.02em;line-height:1.1;
  margin:0;color:#fff;
}
.h3{font-size:20px;font-weight:700;margin:0;color:#fff;letter-spacing:-0.01em}
.lede{color:var(--text-grey);font-size:17px;margin:0;line-height:1.6;max-width:60ch}
section.blue .lede{color:rgba(255,255,255,0.85)}
.cyan{color:var(--accent-cyan)}
.center{text-align:center}
.muted{color:var(--text-grey)}

/* ====== NAV ====== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;
  padding:18px 28px;gap:32px;
  background:transparent;transition:background .25s ease,backdrop-filter .25s ease;
}
.nav.scrolled{background:rgba(7,7,15,0.78);backdrop-filter:saturate(150%) blur(14px)}
.nav.scrolled.on-blue{background:rgba(0,7,168,0.75)}
.brand{
  display:inline-flex;align-items:center;gap:10px;
  font-weight:800;letter-spacing:0.02em;font-size:14px;color:#fff;
}
.brand-mark{
  width:36px;height:36px;border-radius:9px;
  background-image:url('assets/logo.png');
  background-size:cover;background-position:center;
  box-shadow:0 0 0 1px rgba(255,255,255,.18) inset, 0 6px 24px rgba(0,17,255,.4);
}
.brand-text{font-size:13px;letter-spacing:0.08em}
.brand-text b{font-weight:800}
.brand-text span{opacity:.65;margin-left:3px}

.nav-links{
  display:flex;align-items:center;gap:2px;margin-left:auto;
}
.nav-links a{
  padding:9px 14px;border-radius:9999px;
  color:rgba(255,255,255,0.75);
  font-size:14px;font-weight:500;
  transition:color .15s,background .15s;
}
.nav-links a:hover{color:#fff;background:rgba(255,255,255,0.07)}
.nav-links a.active{color:var(--accent-cyan);background:rgba(0,229,255,0.08)}

.nav-cta{margin-left:8px}
.menu-btn{
  display:none;
  width:42px;height:42px;border-radius:12px;margin-left:auto;
  background:rgba(255,255,255,.08);place-items:center;color:#fff;
  border:1px solid rgba(255,255,255,.12);
}
.menu-btn svg{width:22px;height:22px}

.mobile-menu{
  position:fixed;inset:0;z-index:99;
  background:linear-gradient(180deg,#0007A8,#0011FF);
  display:none;flex-direction:column;justify-content:center;align-items:center;gap:10px;
}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:22px;font-weight:700;color:#fff;padding:14px 24px;border-radius:12px}
.mobile-menu a:hover{background:rgba(255,255,255,.1)}
.mobile-menu .close{position:absolute;top:18px;right:18px;display:grid}

@media (max-width:980px){
  .nav-links,.nav-cta{display:none}
  .menu-btn{display:grid}
}

/* ====== BUTTONS ====== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  border-radius:9999px;padding:16px 28px;
  font-weight:700;font-size:15px;
  transition:transform .15s ease,box-shadow .2s ease,background .2s,color .2s;
  white-space:nowrap;
}
.btn.sm{padding:11px 18px;font-size:13.5px}
.btn:active{transform:scale(.97)}
.btn-white{background:#fff;color:#0A0A0A;box-shadow:0 0 0 1px rgba(255,255,255,.5),0 0 32px rgba(255,255,255,.2)}
.btn-white:hover{box-shadow:0 0 0 1px rgba(255,255,255,.7),0 0 40px rgba(255,255,255,.32);color:#0A0A0A}
.btn-wa{background:var(--whatsapp-green);color:#0A0A0A;box-shadow:0 0 24px rgba(0,230,118,.25)}
.btn-wa:hover{background:#00d96b;color:#0A0A0A}
.btn-blue{background:var(--brand-blue);color:#fff;box-shadow:0 8px 32px rgba(0,17,255,.4)}
.btn-blue:hover{background:var(--brand-blue-deep);color:#fff}
.btn-ghost-dark{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.22)}
.btn-ghost-dark:hover{border-color:var(--accent-cyan);color:var(--accent-cyan)}
.btn-ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.18)}
.btn svg{width:18px;height:18px}
.btn.full{width:100%}

/* ====== HEROES ====== */
.hero{
  position:relative;
  min-height:92vh;
  padding:140px 0 80px;
  display:flex;align-items:center;
  text-align:center;
}
.hero.left{text-align:left;align-items:center}
.hero .wrap{position:relative;z-index:5}

.orbit-canvas{
  position:absolute;inset:0;width:100%;height:100%;
  z-index:1;pointer-events:none;
}
.orbit-fallback{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background-image:
    radial-gradient(rgba(255,255,255,.15) 1px, transparent 1.5px),
    radial-gradient(rgba(0,229,255,.18) 1.5px, transparent 2px);
  background-size:80px 80px, 140px 140px;
  background-position:0 0, 40px 40px;
  opacity:.45;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(800px 600px at 50% 50%, rgba(0,229,255,0.18), transparent 60%),
    radial-gradient(900px 700px at 0% 100%, rgba(0,7,168,0.35), transparent 60%);
  pointer-events:none;z-index:2;
}
.hero .grid-overlay{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse at center, black 25%, transparent 75%);
}
.hero.short{min-height:60vh;padding:160px 0 80px}
.hero h1.h1{margin:18px auto 22px;max-width:18ch}
.hero.left h1.h1{margin-left:0;margin-right:0}
.hero .sub{color:rgba(255,255,255,.85);font-size:clamp(16px,1.4vw,19px);max-width:60ch;margin:0 auto 36px;line-height:1.55}
.hero.left .sub{margin-left:0;margin-right:0}
.hero .ctas{display:inline-flex;gap:14px;flex-wrap:wrap;justify-content:center}
.hero.left .ctas{justify-content:flex-start}
.hero .feats{
  display:flex;flex-wrap:wrap;gap:24px;margin-top:36px;
  justify-content:center;
  font-size:14px;font-weight:600;color:rgba(255,255,255,0.95);
}
.hero.left .feats{justify-content:flex-start}
.hero .feats .item{display:inline-flex;align-items:center;gap:9px}
.hero .feats .dot{width:9px;height:9px;border-radius:50%;background:var(--whatsapp-green);box-shadow:0 0 12px var(--whatsapp-green)}
.hero .badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px;border-radius:9999px;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  font-size:12px;font-weight:600;letter-spacing:.04em;
  backdrop-filter:blur(4px);
}
.hero .badge .pulse{
  width:7px;height:7px;background:var(--accent-cyan);border-radius:50%;
  box-shadow:0 0 10px var(--accent-cyan);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}

/* ====== CARDS ====== */
.card{
  background:var(--surface-card);
  border:1px solid var(--hairline);
  border-radius:16px;
  padding:28px;
  transition:transform .2s,border-color .25s;
}
.card:hover{border-color:rgba(255,255,255,.16);transform:translateY(-2px)}
.card-icon{
  width:56px;height:56px;border-radius:12px;
  background:var(--brand-blue);
  display:grid;place-items:center;color:#fff;
  box-shadow:0 8px 24px rgba(0,17,255,.3);
}
.card-icon.small{width:44px;height:44px;border-radius:10px}
.card-icon svg{width:28px;height:28px}
.card-icon.small svg{width:22px;height:22px}
.card h3{font-size:20px;font-weight:700;margin:22px 0 10px;color:#fff;letter-spacing:-0.01em}
.card p{color:var(--text-grey);font-size:15px;margin:0;line-height:1.6}

.grid{display:grid;gap:20px}
.grid.cols-2{grid-template-columns:1fr}
.grid.cols-3{grid-template-columns:1fr}
.grid.cols-4{grid-template-columns:1fr}
@media (min-width:640px){
  .grid.cols-2{grid-template-columns:1fr 1fr}
  .grid.cols-4{grid-template-columns:1fr 1fr}
}
@media (min-width:980px){
  .grid.cols-3{grid-template-columns:repeat(3,1fr)}
  .grid.cols-4{grid-template-columns:repeat(4,1fr)}
}

.section-head{margin-bottom:48px;text-align:center}
.section-head .eyebrow{margin-bottom:14px}
.section-head .lede{margin:14px auto 0}
.section-head.left{text-align:left}
.section-head.left .lede{margin-left:0}

/* ====== STEPS ====== */
.step-card{padding:36px 28px}
.step-circle{
  width:120px;height:120px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%, #2030FF, var(--brand-blue) 55%, var(--brand-blue-deep) 100%);
  display:grid;place-items:center;
  margin:0 auto 20px;color:#fff;position:relative;
  box-shadow:0 12px 50px rgba(0,17,255,.45),inset 0 0 0 1px rgba(255,255,255,.18);
}
.step-circle svg{width:46px;height:46px}
.step-circle .num{
  position:absolute;top:-6px;right:-6px;
  background:#0A0A0A;border:1px solid rgba(255,255,255,.2);
  border-radius:9999px;padding:5px 11px;
  font-size:11px;font-weight:800;color:#fff;letter-spacing:.06em;
}
.step-card h3,.step-card p{text-align:center}
.step-card p{max-width:36ch;margin:8px auto 0}

/* ====== PRICING ====== */
.pricing-card{
  background:var(--surface-card);
  border:1px solid var(--hairline);
  border-radius:18px;
  padding:28px;
  transition:background .25s,border-color .25s,transform .15s,box-shadow .25s;
  cursor:pointer;position:relative;
  display:flex;flex-direction:column;gap:0;
}
.pricing-card:hover{border-color:rgba(255,255,255,.16)}
.pricing-card .top{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:12px}
.pricing-card .radio{
  width:24px;height:24px;border-radius:50%;
  border:2px solid rgba(255,255,255,.32);
  display:grid;place-items:center;flex:none;
  transition:all .2s;
}
.pricing-card .radio::after{content:'';width:10px;height:10px;border-radius:50%;background:transparent;transition:background .2s}
.pricing-card .name{font-size:18px;font-weight:700;color:#fff;flex:1}
.pricing-card .price{font-size:30px;font-weight:800;letter-spacing:-0.02em;color:#fff;line-height:1}
.pricing-card .price small{font-size:12px;font-weight:600;color:var(--text-grey);letter-spacing:0;display:block;margin-top:4px}
.pricing-card .desc{color:var(--text-grey);font-size:14.5px;margin:8px 0 0;line-height:1.55}
.pricing-card .popular{
  position:absolute;top:-12px;left:24px;
  background:#fff;color:var(--brand-blue);
  border-radius:9999px;padding:6px 14px;
  font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  box-shadow:0 6px 20px rgba(255,255,255,.2);
}
.pricing-card.selected{
  background:var(--brand-blue);
  border-color:transparent;color:#fff;
  box-shadow:0 16px 48px rgba(0,17,255,.45);
}
.pricing-card.selected .desc{color:rgba(255,255,255,.9)}
.pricing-card.selected .radio{border-color:#fff;background:#fff}
.pricing-card.selected .radio::after{background:var(--brand-blue)}
.pricing-card.selected .price small{color:rgba(255,255,255,.75)}
.pricing-card .expand{
  width:100%;margin-top:14px;
  display:flex;align-items:center;justify-content:space-between;
  padding:11px 14px;border-radius:10px;
  background:rgba(255,255,255,.06);
  font-size:13px;font-weight:600;color:var(--text-grey);
}
.pricing-card.selected .expand{background:rgba(255,255,255,.18);color:#fff}
.pricing-card .expand svg{width:16px;height:16px;transition:transform .25s}
.pricing-card.open .expand svg{transform:rotate(180deg)}
.pricing-card .includes{max-height:0;overflow:hidden;transition:max-height .3s ease;color:var(--text-grey);font-size:14px}
.pricing-card.selected .includes{color:rgba(255,255,255,.9)}
.pricing-card.open .includes{max-height:520px}
.pricing-card .includes ul{list-style:none;padding:14px 4px 4px;margin:0;display:flex;flex-direction:column;gap:8px}
.pricing-card .includes li{display:flex;gap:10px;align-items:flex-start;font-size:14px}
.pricing-card .includes li::before{
  content:'';width:16px;height:16px;flex:none;margin-top:3px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%2300E676' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><path d='M3 8.5l3 3 7-7'/></svg>");
  background-size:contain;background-repeat:no-repeat;
}
.pricing-card.selected .includes li::before{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23ffffff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><path d='M3 8.5l3 3 7-7'/></svg>");
}

/* ====== MONTHLY ====== */
.plan-card{
  background:var(--surface-card);border:1px solid var(--hairline);
  border-radius:16px;padding:24px;
  display:flex;align-items:flex-start;gap:18px;
  transition:opacity .25s;
}
.plan-card .body{flex:1}
.plan-card .head-row{display:flex;align-items:center;gap:10px;margin-bottom:6px;flex-wrap:wrap}
.plan-card .name{font-size:17px;font-weight:700;color:#fff}
.plan-card .price{font-size:26px;font-weight:800;color:#fff;letter-spacing:-0.02em;margin-top:6px}
.plan-card .price small{font-size:13px;color:var(--text-grey);font-weight:600}
.plan-card .desc{font-size:14px;color:var(--text-grey);margin:8px 0 0}
.req-badge{
  background:var(--brand-blue);color:#fff;
  border-radius:9999px;padding:4px 10px;
  font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  white-space:nowrap;
}
.toggle{
  width:56px;height:32px;border-radius:9999px;
  background:#2A2A30;position:relative;flex:none;cursor:pointer;
  transition:background .2s;border:none;
}
.toggle.on{background:var(--brand-blue)}
.toggle-thumb{position:absolute;top:3px;left:3px;width:26px;height:26px;background:#fff;border-radius:50%;transition:transform .2s ease}
.toggle.on .toggle-thumb{transform:translateX(24px)}
.replaces-note{
  font-size:12.5px;color:var(--text-grey);margin-top:12px;
  padding:10px 14px;border-radius:10px;
  background:rgba(0,17,255,.08);border:1px solid rgba(0,17,255,.22);
}

/* ====== SUMMARY ====== */
.summary{border-radius:16px;overflow:hidden;border:1px solid var(--hairline);background:var(--surface-card)}
.summary-head{
  background:var(--brand-blue);color:#fff;padding:18px 22px;
  font-weight:700;font-size:17px;letter-spacing:-0.01em;
  display:flex;align-items:center;justify-content:space-between;
}
.summary-head svg{width:18px;height:18px}
.summary-list{padding:8px 22px}
.summary-row{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--hairline);font-size:15px}
.summary-row:last-child{border-bottom:none}
.summary-row .lbl b{color:#fff;font-weight:600;display:block;font-size:15.5px}
.summary-row .lbl small{display:block;font-size:12px;color:var(--text-grey);margin-top:2px}
.summary-row .val{color:#fff;font-weight:700}
.summary-totals{padding:6px 22px 22px}
.summary-totals .row{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 16px;margin-top:8px;border-radius:10px;
  background:rgba(255,255,255,.04);
  font-size:13px;letter-spacing:.06em;text-transform:uppercase;font-weight:700;color:var(--text-grey);
}
.summary-totals .row.year1{
  background:var(--brand-blue);color:#fff;
  box-shadow:0 12px 32px rgba(0,17,255,.35);
}
.summary-totals .row .v{font-size:22px;font-weight:800;letter-spacing:-0.02em;text-transform:none;color:#fff}
.summary-totals .row .v small{font-size:12px;font-weight:600;color:rgba(255,255,255,.7);margin-left:4px;letter-spacing:0;text-transform:none}

/* ====== WORK GRID ====== */
.work-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media (min-width:720px){.work-grid{grid-template-columns:1fr 1fr}}
.work-card{
  background:var(--surface-card);border:1px solid var(--hairline);
  border-radius:16px;overflow:hidden;
  transition:transform .25s,border-color .25s;
}
.work-card:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.18)}
.work-preview{
  aspect-ratio:16/10;position:relative;overflow:hidden;
  background:linear-gradient(135deg, #0A0A14, #16162a);
  border-bottom:1px solid var(--hairline);
  display:grid;place-items:center;
}
.work-preview::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 30% 30%, rgba(0,17,255,.4), transparent 50%),
             radial-gradient(circle at 70% 70%, rgba(0,229,255,.25), transparent 50%);
}
.work-preview .url{
  position:relative;z-index:2;
  font-family:monospace;font-size:13px;color:rgba(255,255,255,.7);
  padding:8px 14px;border-radius:9999px;
  background:rgba(0,0,0,.45);border:1px solid rgba(255,255,255,.14);
  backdrop-filter:blur(8px);
}
.work-meta{padding:22px 24px;display:flex;justify-content:space-between;align-items:center;gap:16px}
.work-meta .industry{font-family:monospace;font-size:11px;color:var(--text-grey-soft);letter-spacing:.1em;text-transform:uppercase}
.work-meta h3{font-size:18px;margin-top:4px}

/* ====== BENEFITS COMPARE ====== */
.compare{border:1px solid var(--hairline);border-radius:18px;overflow:hidden;background:var(--surface-card)}
.compare-row{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;align-items:stretch;border-top:1px solid var(--hairline)}
.compare-row:first-child{border-top:none;background:rgba(255,255,255,.03)}
.compare-cell{padding:16px 18px;font-size:14.5px;color:var(--text-grey)}
.compare-cell.head{font-family:Inter;font-weight:700;font-size:14px;color:#fff}
.compare-cell.us{background:rgba(0,17,255,.1);font-weight:600;color:#fff;border-left:1px solid rgba(0,17,255,.3);border-right:1px solid rgba(0,17,255,.3)}
.compare-cell.row-label{font-weight:600;color:#fff}
@media (max-width:780px){
  .compare-row{grid-template-columns:1.4fr 1fr}
  .compare-cell:nth-child(3),.compare-cell:nth-child(4){display:none}
}

/* ====== FAQ ====== */
.faq-cat{
  font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--brand-blue);color:#3D52FF;margin:40px 0 14px;
}
.faq-cat:first-of-type{margin-top:0}
.faq-item{
  background:var(--surface-card);border:1px solid var(--hairline);border-radius:16px;
  margin-bottom:10px;overflow:hidden;
}
.faq-q{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:22px 24px;text-align:left;
  font-size:16px;font-weight:600;color:#fff;line-height:1.4;
}
.faq-icon{
  width:32px;height:32px;border-radius:50%;
  background:var(--brand-blue);display:grid;place-items:center;
  flex:none;transition:transform .25s ease;
}
.faq-icon svg{width:16px;height:16px;color:#fff}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;color:var(--text-grey);font-size:15px;padding:0 24px}
.faq-item.open .faq-a{max-height:520px;padding-bottom:22px}

/* ====== CONTACT ====== */
.contact-grid{display:grid;grid-template-columns:1fr;gap:18px}
@media (min-width:880px){.contact-grid{grid-template-columns:repeat(3,1fr)}}
.contact-card{
  padding:30px 28px;border-radius:16px;border:1px solid var(--hairline);
  background:var(--surface-card);transition:transform .25s,border-color .25s;
}
.contact-card:hover{transform:translateY(-3px);border-color:rgba(255,255,255,.16)}
.contact-card.primary{
  background:linear-gradient(135deg, #003c1f, #052015);
  border-color:rgba(0,230,118,.3);position:relative;overflow:hidden;
}
.contact-card.primary::before{
  content:'';position:absolute;right:-40px;top:-40px;
  width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle, rgba(0,230,118,.25), transparent 60%);
}
.contact-card h3{margin:14px 0 8px;font-size:19px}
.contact-card p{color:var(--text-grey);font-size:14.5px;margin:0 0 18px}
.contact-card.primary p{color:rgba(255,255,255,.78)}
.contact-card .ic{
  width:48px;height:48px;border-radius:12px;
  display:grid;place-items:center;color:#fff;
  background:var(--brand-blue);
}
.contact-card.primary .ic{background:var(--whatsapp-green);color:#0A0A0A}

/* ====== FORM ====== */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.field label{font-size:12px;font-weight:700;color:var(--text-grey);letter-spacing:.06em;text-transform:uppercase}
.field input,.field textarea,.field select{
  font-family:inherit;font-size:15px;
  padding:14px 16px;
  border:1px solid var(--hairline-strong);
  border-radius:12px;
  background:#0F0F14;color:#fff;
  transition:border-color .15s,box-shadow .15s;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--brand-blue);
  box-shadow:0 0 0 4px rgba(0,17,255,.18);
}
.field textarea{resize:vertical;min-height:120px}

/* ====== BLOG ====== */
.blog-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media (min-width:720px){.blog-grid{grid-template-columns:1fr 1fr}}
@media (min-width:1024px){.blog-grid{grid-template-columns:repeat(3,1fr)}}
.blog-card{
  background:var(--surface-card);border:1px solid var(--hairline);
  border-radius:16px;overflow:hidden;
  transition:transform .25s,border-color .25s;
  display:flex;flex-direction:column;
}
.blog-card:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.18)}
.blog-cover{
  aspect-ratio:16/10;position:relative;overflow:hidden;
  background:linear-gradient(135deg, var(--brand-blue-deep), var(--brand-blue));
}
.blog-cover::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(400px 200px at 70% 30%, rgba(0,229,255,.4), transparent 60%);
}
.blog-cover .tag{
  position:absolute;top:14px;left:14px;z-index:2;
  font-family:monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  padding:6px 12px;border-radius:9999px;
  background:rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.18);
  color:#fff;backdrop-filter:blur(8px);
}
.blog-body{padding:24px;display:flex;flex-direction:column;gap:8px;flex:1}
.blog-body .date{font-family:monospace;font-size:11.5px;color:var(--text-grey-soft);letter-spacing:.06em}
.blog-body h3{font-size:18px;margin:6px 0 4px;line-height:1.3}
.blog-body p{font-size:14.5px;color:var(--text-grey);margin:0;flex:1}
.blog-body .read{margin-top:14px;font-size:13.5px;font-weight:700;color:var(--accent-cyan);display:inline-flex;gap:6px;align-items:center}

/* clickable card link wrapper */
a.blog-card{text-decoration:none;color:inherit;display:flex;flex-direction:column}
a.blog-card:hover .read{gap:10px}

/* svg cover fills the cover area */
.blog-cover svg{position:absolute;inset:0;width:100%;height:100%;display:block}
.blog-cover{background:#0A0A0F}
.blog-cover::before{display:none}
.blog-cover .tag{
  background:rgba(10,10,15,.6);
  border:1px solid rgba(255,255,255,.18);
}

/* featured (first) card spans 2 cols on wide */
@media (min-width:1024px){
  .blog-grid{grid-template-columns:repeat(3,1fr);grid-auto-flow:dense}
  a.blog-card.featured{grid-column:span 2;flex-direction:row}
  a.blog-card.featured .blog-cover{flex:1.1;aspect-ratio:auto}
  a.blog-card.featured .blog-body{flex:1;padding:36px;justify-content:center}
  a.blog-card.featured h3{font-size:26px;letter-spacing:-0.01em;line-height:1.18}
  a.blog-card.featured .blog-body p{font-size:15.5px;max-width:42ch}
}

/* ====== BLOG POST ARTICLE ====== */
.post{position:relative}
.post-hero{position:relative;min-height:62vh;display:flex;align-items:flex-end;padding:140px 0 60px;overflow:hidden}
.post-cover{position:absolute;inset:0;z-index:0}
.post-cover svg{position:absolute;inset:0;width:100%;height:100%;display:block}
.post-cover::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,15,.35) 0%,rgba(10,10,15,.55) 40%,#0A0A0F 100%)}
.post-hero-inner{position:relative;z-index:2;width:100%}
.post-hero .back-link{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13px;font-weight:600;letter-spacing:.06em;
  color:rgba(255,255,255,.7);
  padding:8px 14px 8px 10px;border-radius:9999px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  transition:background .2s,color .2s;
  margin-bottom:24px;
}
.post-hero .back-link:hover{background:rgba(255,255,255,.12);color:#fff}
.post-hero .back-link svg{width:14px;height:14px}
.post-tag{
  display:inline-block;
  font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:#00B4D8;
  background:rgba(0,180,216,.12);
  border:1px solid rgba(0,180,216,.28);
  padding:6px 12px;border-radius:9999px;
}
.post-title{
  font-family:'Playfair Display',Georgia,serif;
  font-size:clamp(36px,5.4vw,68px);
  font-weight:600;line-height:1.04;letter-spacing:-0.02em;
  color:#fff;margin:18px 0 18px;max-width:18ch;
  text-wrap:balance;
}
.post-meta{
  display:flex;gap:10px;align-items:center;
  color:rgba(255,255,255,.65);
  font-size:13.5px;font-family:monospace;letter-spacing:.06em;
}
.post-meta .sep{opacity:.5}

.post-body{padding:56px 28px 80px}
.post-prose{font-size:19px;line-height:1.75;color:#E2E2E8;font-weight:400}
.post-prose p{margin:0 0 22px}
.post-prose p:first-of-type::first-line{font-weight:600;color:#fff}
.post-prose em{color:#9BE1F2;font-style:italic;font-family:'Playfair Display',Georgia,serif;font-weight:500}
.post-prose strong{color:#fff;font-weight:700}
.post-prose a{color:#00B4D8;text-decoration:underline;text-underline-offset:3px}

.post-prose p:first-of-type:first-letter{
  font-family:'Playfair Display',Georgia,serif;
  float:left;font-weight:600;
  font-size:78px;line-height:.85;
  padding:6px 12px 0 0;
  color:#fff;
}

@media (max-width:680px){
  .post-prose{font-size:17px;line-height:1.7}
  .post-prose p:first-of-type:first-letter{font-size:60px}
}

.post-cta{
  margin:56px 0 36px;
  background:linear-gradient(135deg,rgba(0,17,255,.14) 0%,rgba(0,180,216,.08) 100%);
  border:1px solid rgba(0,17,255,.28);
  border-radius:18px;
  padding:28px 30px;
  display:grid;grid-template-columns:1fr;gap:20px;align-items:center;
}
@media (min-width:780px){.post-cta{grid-template-columns:1.4fr auto}}
.post-cta-actions{display:flex;gap:10px;flex-wrap:wrap}

.share-bar{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:24px 0 8px;border-top:1px solid var(--hairline);
  margin-top:8px;flex-wrap:wrap;
}
.share-label{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-grey-soft);font-weight:700}
.share-buttons{display:flex;gap:8px;flex-wrap:wrap}
.share-btn{
  display:inline-flex;align-items:center;gap:8px;
  width:42px;height:42px;border-radius:50%;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  color:#fff;cursor:pointer;
  justify-content:center;
  transition:background .2s,border-color .2s,transform .15s,color .2s,width .2s;
}
.share-btn:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.2)}
.share-btn:active{transform:scale(.94)}
.share-btn svg{width:18px;height:18px}
.share-btn.copy{width:auto;padding:0 16px;border-radius:9999px;font-size:13px;font-weight:600}
.share-btn.copy span{display:inline}
.share-btn.copy.copied{background:rgba(0,230,118,.16);border-color:rgba(0,230,118,.4);color:#52E59A}

.more-head{text-align:left;margin-bottom:28px}

/* ====== FOOTER ====== */
footer{
  background:linear-gradient(180deg,#000B6E 0%,#000838 100%);
  position:relative;overflow:hidden;padding:80px 0 32px;
}
footer .constellation{position:absolute;inset:0;pointer-events:none;z-index:0;opacity:.95}
footer .wrap{position:relative;z-index:1}
.foot-top{
  display:grid;grid-template-columns:1fr;gap:36px;
  padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.08);
}
@media (min-width:720px){.foot-top{grid-template-columns:1.6fr 1fr 1fr 1fr}}
.foot-brand .brand{margin-bottom:14px}
.foot-tagline{color:rgba(255,255,255,.7);font-size:14px;line-height:1.6;margin:0 0 24px;max-width:34ch}
.foot-h{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#fff;margin:0 0 16px}
.foot-links{display:flex;flex-direction:column;gap:10px}
.foot-links a{color:rgba(255,255,255,.72);font-size:14.5px;display:inline-flex;align-items:center;gap:10px}
.foot-links a:hover{color:#fff}
.foot-links a svg{width:18px;height:18px;flex:none;color:rgba(255,255,255,.5)}
.socials{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}
.social{
  width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;color:#fff;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);
  transition:transform .15s, background .2s;
}
.social:hover{transform:translateY(-2px)}
.social.wa{background:var(--whatsapp-green);color:#0a0a0a;border-color:transparent}
.social.ig{background:linear-gradient(135deg,#feda75,#fa7e1e 30%,#d62976 60%,#962fbf 80%,#4f5bd5);border-color:transparent}
.social.li{background:#0A66C2;border-color:transparent}
.social.fb{background:#3A3B3C;border-color:transparent}
.social.tt{background:#fff;color:#000;border-color:transparent}
.social svg{width:20px;height:20px}
.foot-bottom{padding-top:24px;display:flex;flex-direction:column;gap:8px;font-size:12.5px;color:rgba(255,255,255,.55);letter-spacing:.02em}
.foot-bottom .legal-row{display:flex;gap:18px;flex-wrap:wrap}
.foot-bottom a:hover{color:#fff}
@media (min-width:720px){
  .foot-bottom{flex-direction:row;justify-content:space-between;align-items:center}
}

/* ====== WHATSAPP FLOAT ====== */
.wa-float{
  position:fixed;right:22px;bottom:22px;z-index:80;
  width:60px;height:60px;border-radius:50%;
  background:var(--whatsapp-green);
  display:grid;place-items:center;color:#0A0A0A;
  box-shadow:0 12px 30px rgba(0,230,118,.4);
  transition:transform .2s;
}
.wa-float:hover{transform:scale(1.08)}
.wa-float::before,.wa-float::after{
  content:'';position:absolute;inset:0;border-radius:50%;
  border:2px solid var(--whatsapp-green);animation:waPulse 3s ease-out infinite;
}
.wa-float::after{animation-delay:1.5s}
@keyframes waPulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.8);opacity:0}}

/* ====== LEGAL ====== */
.legal-content{max-width:760px;margin:0 auto}
.legal-content h2{font-size:22px;margin:40px 0 12px;color:#fff;font-weight:700}
.legal-content p,.legal-content ul{color:var(--text-grey);font-size:15.5px}
.legal-content ul{padding-left:1.2em}

/* ====== FADE IN ====== */
.fade-in{opacity:0;transform:translateY(20px);transition:opacity .7s ease, transform .7s ease}
.fade-in.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .fade-in{opacity:1;transform:none}
}

/* ====== FINAL CTA BLOCK ====== */
.final-cta{
  background:var(--surface-card);border:1px solid var(--hairline);
  border-radius:18px;padding:48px 32px;text-align:center;
  position:relative;overflow:hidden;
}
.final-cta::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(600px 200px at 50% 0%, rgba(0,17,255,.15), transparent 70%);
}
.final-cta > *{position:relative}
.final-cta h3{font-size:28px;font-weight:800;letter-spacing:-0.02em;margin:0 0 12px;color:#fff}
.final-cta p{color:var(--text-grey);margin:0 0 24px;max-width:46ch;margin-left:auto;margin-right:auto}

/* ====== STATS ====== */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
@media (min-width:720px){.stats{grid-template-columns:repeat(4,1fr)}}
.stat .num{font-size:36px;font-weight:800;letter-spacing:-0.02em;color:var(--accent-cyan);font-family:Inter}
section.black .stat .num{color:#3D52FF}
.stat .lbl{font-family:monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-grey-soft);margin-top:6px}

/* ====== HOME PRICING (PLAN CARDS) ====== */
.plans{display:flex;flex-direction:column;gap:24px}
.plan{
  position:relative;
  background:var(--surface-card);
  border:1px solid var(--hairline);
  border-radius:18px;
  padding:32px 32px 30px;
  transition:border-color .25s,transform .2s;
}
.plan:hover{border-color:rgba(255,255,255,.14)}
.plan .plan-tag{
  display:inline-flex;align-items:center;
  background:rgba(0,17,255,0.18);
  color:#7E8CFF;
  border-radius:9999px;
  padding:6px 14px;
  font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  margin-bottom:14px;
}
.plan .plan-tag.green{background:rgba(0,230,118,0.14);color:#52E59A}
.plan .plan-title{
  font-size:clamp(22px,2.3vw,28px);font-weight:800;color:#fff;letter-spacing:-0.02em;
  margin:0;
}
.plan .plan-desc{
  color:var(--text-grey);font-size:15px;line-height:1.6;
  margin:14px 0 0;max-width:62ch;
}
.plan .plan-price{
  position:absolute;top:32px;right:32px;text-align:right;
}
.plan .plan-price .amt{font-size:clamp(28px,3vw,38px);font-weight:800;color:#fff;letter-spacing:-0.02em;line-height:1}
.plan .plan-price .per{display:block;font-size:13px;color:var(--text-grey);font-weight:500;margin-top:6px}
.plan .plan-divider{
  height:1px;background:var(--hairline);margin:24px 0 22px;
}
.plan .plan-features{
  display:grid;grid-template-columns:1fr;gap:12px 28px;
  margin:0;padding:0;list-style:none;
}
@media (min-width:780px){
  .plan .plan-features{grid-template-columns:1fr 1fr}
}
.plan .plan-features li{
  display:flex;align-items:flex-start;gap:11px;
  color:var(--text-grey);font-size:14.5px;line-height:1.5;
}
.plan .plan-features li::before{
  content:'';flex:none;width:16px;height:16px;margin-top:3px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%237E8CFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='3 8 7 12 13 4'/></svg>");
  background-size:contain;background-repeat:no-repeat;
}
.plan .plan-cta{
  display:flex;gap:12px;flex-wrap:wrap;margin-top:26px;
}
.plan .btn-tpl{
  background:transparent;color:#fff;
  border:1px solid rgba(255,255,255,.18);
  padding:14px 22px;font-size:14px;
}
.plan .btn-tpl:hover{border-color:var(--accent-cyan);color:var(--accent-cyan)}
.plan .btn-tpl svg{width:18px;height:18px}

/* popular wrapper */
.plan-popular{
  position:relative;
  border-radius:22px;
  padding:0;
  background:linear-gradient(180deg,var(--brand-blue) 0%,var(--brand-blue-mid) 100%);
  box-shadow:0 24px 80px -20px rgba(0,17,255,.55),
             0 0 0 1px rgba(0,17,255,.4);
}
.plan-popular .popular-bar{
  display:flex;align-items:center;justify-content:center;
  padding:11px 16px;
  font-size:12px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:#fff;
}
.plan-popular .plan{
  margin:0 4px 4px;border-radius:0 0 19px 19px;
  border:none;
  background:#0F0F16;
}

/* coming soon */
.plan.coming{position:relative;overflow:hidden}
.plan.coming .plan-content{filter:blur(4px);opacity:.4;pointer-events:none}
.plan.coming .plan-content > .plan-cta{display:none}
.plan.coming .coming-overlay{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  text-align:center;
}
.plan.coming .coming-lock{
  width:54px;height:54px;border-radius:50%;
  background:var(--brand-blue);
  display:grid;place-items:center;color:#fff;
  box-shadow:0 12px 36px rgba(0,17,255,.5);
}
.plan.coming .coming-lock svg{width:24px;height:24px}
.plan.coming .coming-title{font-size:20px;font-weight:800;color:#fff;margin:0}
.plan.coming .coming-sub{font-size:14px;color:var(--text-grey);margin:0}

.plans-coming{display:grid;grid-template-columns:1fr;gap:24px;margin-top:24px}
@media (min-width:860px){.plans-coming{grid-template-columns:1fr 1fr}}

/* calc CTA card */
.calc-cta{
  margin-top:24px;
  background:var(--surface-card);
  border:1px solid var(--hairline);
  border-radius:18px;
  padding:48px 32px;
  text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:14px;
  transition:border-color .25s;
}
.calc-cta:hover{border-color:rgba(255,255,255,.16)}
.calc-cta .calc-ico{
  width:54px;height:54px;border-radius:14px;
  background:rgba(0,17,255,0.18);
  display:grid;place-items:center;color:#7E8CFF;
  border:1px solid rgba(0,17,255,0.28);
}
.calc-cta .calc-ico svg{width:26px;height:26px}
.calc-cta h3{font-size:24px;font-weight:800;color:#fff;margin:6px 0 0;letter-spacing:-0.01em}
.calc-cta p{color:var(--text-grey);font-size:15px;max-width:50ch;margin:0 0 8px;line-height:1.55}

.coming-eyebrow{
  display:flex;align-items:center;gap:14px;
  margin:60px 0 28px;
  color:var(--text-grey-soft);
  font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
}
.coming-eyebrow::before,.coming-eyebrow::after{
  content:'';flex:1;height:1px;background:var(--hairline);
}

/* ====== TEMPLATE GALLERY MODAL ====== */
.tpl-modal{
  position:fixed;inset:0;z-index:200;
  display:none;align-items:center;justify-content:center;
  padding:24px;
  font-family:'Inter',system-ui,sans-serif;
}
.tpl-modal.open{display:flex}
.tpl-backdrop{
  position:absolute;inset:0;
  background:rgba(4,4,9,.75);
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  animation:tplFade .25s ease;
}
@keyframes tplFade{from{opacity:0}to{opacity:1}}
@keyframes tplLift{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}

.tpl-shell{
  position:relative;
  width:100%;max-width:1180px;max-height:calc(100vh - 48px);
  display:flex;flex-direction:column;
  background:#0E0E14;
  border:1px solid rgba(255,255,255,.08);
  border-radius:22px;
  overflow:hidden;
  box-shadow:0 40px 120px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.04) inset;
  animation:tplLift .35s cubic-bezier(.2,.7,.2,1);
}
.tpl-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 24px;
  border-bottom:1px solid rgba(255,255,255,.06);
  flex:none;
}
.tpl-eyebrow{
  font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text-grey);
}
.tpl-eyebrow b{color:#fff;font-weight:700}
.tpl-close{
  width:38px;height:38px;border-radius:50%;
  display:grid;place-items:center;color:#fff;
  background:rgba(255,255,255,.06);
  transition:background .2s,transform .15s;
}
.tpl-close:hover{background:rgba(255,255,255,.14)}
.tpl-close:active{transform:scale(.94)}
.tpl-close svg{width:18px;height:18px}

.tpl-stage{
  position:relative;
  flex:1;min-height:0;
  background:#0A0A0F;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  overflow:hidden;
}
.tpl-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  color:#fff;display:grid;place-items:center;z-index:3;
  transition:background .2s,transform .15s;
}
.tpl-arrow:hover{background:rgba(255,255,255,.18)}
.tpl-arrow:active{transform:translateY(-50%) scale(.93)}
.tpl-arrow.prev{left:18px}
.tpl-arrow.next{right:18px}
.tpl-arrow svg{width:20px;height:20px}

.tpl-frame-wrap{
  position:relative;
  width:100%;max-width:980px;
  aspect-ratio:16/10;
  border-radius:14px;overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.55);
}
.tpl-frames{position:absolute;inset:0}
.tpl-frame{
  position:absolute;inset:0;
  opacity:0;pointer-events:none;
  transition:opacity .35s ease;
  overflow:hidden;
}
.tpl-frame.active{opacity:1;pointer-events:auto}

.tpl-thumbs{
  display:flex;gap:10px;justify-content:center;
  padding:16px 24px;
  border-top:1px solid rgba(255,255,255,.06);
  flex:none;
}
.tpl-thumb{
  width:118px;height:74px;
  border-radius:8px;overflow:hidden;
  border:2px solid transparent;
  background:#0a0a0f;
  cursor:pointer;position:relative;
  transition:border-color .2s,transform .15s;
}
.tpl-thumb:hover{transform:translateY(-2px)}
.tpl-thumb.active{border-color:#fff}
.tpl-thumb .mini{
  position:absolute;inset:0;
  transform:scale(.115);transform-origin:0 0;
  width:1024px;height:640px;
  pointer-events:none;
}

.tpl-foot{
  padding:18px 24px 22px;
  border-top:1px solid rgba(255,255,255,.06);
  display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center;
  flex:none;
}
.tpl-meta h4{margin:0;font-size:17px;font-weight:700;color:#fff;letter-spacing:-0.01em}
.tpl-meta p{margin:4px 0 0;font-size:13.5px;color:var(--text-grey)}
.tpl-foot .btn{padding:14px 22px;font-size:14.5px}

@media (max-width:780px){
  .tpl-modal{padding:0}
  .tpl-shell{max-height:100vh;border-radius:0}
  .tpl-arrow{width:38px;height:38px}
  .tpl-arrow.prev{left:8px}.tpl-arrow.next{right:8px}
  .tpl-thumbs{padding:12px;gap:8px;overflow-x:auto;scrollbar-width:none}
  .tpl-thumb{flex:none;width:96px;height:60px}
  .tpl-foot{grid-template-columns:1fr;text-align:left}
  .tpl-foot .btn{width:100%}
  .tpl-frame-wrap{aspect-ratio:4/3}
}

/* ====== TEMPLATE FRAMES (mini-websites) ====== */
.tpl-frame .mini-site{
  width:100%;height:100%;
  display:flex;flex-direction:column;
  overflow:hidden;font-family:'Inter',system-ui,sans-serif;
}
.tpl-frame .ms-nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 28px;flex:none;font-size:12px;
}
.tpl-frame .ms-nav .links{display:flex;gap:18px;color:rgba(0,0,0,.55);font-weight:500}
.tpl-frame .ms-hero{flex:1;display:flex;position:relative;min-height:0}

/* --- A: STUDIO (Consulting) --- */
.tpl-a{background:#F2EBDD;color:#1A1A1A}
.tpl-a .ms-nav{color:#1A1A1A}
.tpl-a .ms-nav .brand{font-family:'Playfair Display',Georgia,serif;font-weight:700;font-size:15px;letter-spacing:-0.01em}
.tpl-a .ms-hero{padding:0 28px 24px;gap:24px;align-items:stretch}
.tpl-a .ms-copy{flex:1;display:flex;flex-direction:column;justify-content:center;padding:8px 0 32px;min-width:0}
.tpl-a .ms-eyebrow{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:#8a7c5e;font-weight:700;margin-bottom:12px}
.tpl-a h1{font-family:'Playfair Display',Georgia,serif;font-weight:600;font-size:46px;line-height:1.02;letter-spacing:-0.025em;margin:0;color:#16140F}
.tpl-a h1 em{font-style:italic;color:#9B7A3A}
.tpl-a .ms-sub{margin:14px 0 22px;font-size:13px;line-height:1.55;color:#4a443a;max-width:32ch}
.tpl-a .pill{display:inline-flex;align-items:center;gap:8px;background:#16140F;color:#F2EBDD;padding:11px 18px;border-radius:9999px;font-size:12px;font-weight:600;width:fit-content}
.tpl-a .ms-img{flex:1.1;border-radius:10px;background:#C9B58B center/cover no-repeat url('https://images.unsplash.com/photo-1497366216548-37526070297c?w=900&q=80');position:relative}
.tpl-a .ms-chip{position:absolute;left:14px;bottom:14px;background:rgba(255,255,255,.92);backdrop-filter:blur(6px);padding:8px 12px;border-radius:8px;font-size:11px;color:#1A1A1A;display:flex;align-items:center;gap:8px}
.tpl-a .ms-chip .dot{width:6px;height:6px;border-radius:50%;background:#2E9C5F}

/* --- B: BISTRO (Restaurant) --- */
.tpl-b{background:#1B0F0A;color:#F5E9D6}
.tpl-b .ms-nav{color:#F5E9D6}
.tpl-b .ms-nav .brand{font-family:'Playfair Display',Georgia,serif;font-style:italic;font-size:16px}
.tpl-b .ms-nav .links{color:rgba(245,233,214,.7)}
.tpl-b .ms-hero{position:relative;padding:0}
.tpl-b .ms-bg{position:absolute;inset:0;background:#3a1e10 center/cover no-repeat url('https://images.unsplash.com/photo-1414235077428-338989a2e8c0?w=1200&q=80')}
.tpl-b .ms-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(27,15,10,.35) 0%,rgba(27,15,10,.85) 90%)}
.tpl-b .ms-content{position:relative;width:100%;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding:28px 32px 32px;gap:8px}
.tpl-b .ms-eyebrow{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:#E8B86A;font-weight:700}
.tpl-b h1{font-family:'Playfair Display',Georgia,serif;font-weight:500;font-size:60px;letter-spacing:-0.02em;line-height:.95;margin:6px 0 14px;color:#F5E9D6}
.tpl-b h1 em{font-style:italic;color:#E8B86A}
.tpl-b .ms-meta{display:flex;gap:24px;font-size:11.5px;color:rgba(245,233,214,.7);margin-bottom:18px}
.tpl-b .ms-meta b{color:#F5E9D6;font-weight:600;display:block;margin-bottom:2px;letter-spacing:.06em;font-size:10px;text-transform:uppercase}
.tpl-b .pill{align-self:flex-start;display:inline-flex;align-items:center;gap:8px;background:#E8B86A;color:#1B0F0A;padding:12px 20px;border-radius:9999px;font-size:12.5px;font-weight:700}

/* --- C: GLOW (Beauty/Salon) --- */
.tpl-c{background:#F6E6E0;color:#2B1B1A}
.tpl-c .ms-nav{color:#2B1B1A;padding:16px 30px}
.tpl-c .ms-nav .brand{font-family:'Playfair Display',Georgia,serif;font-style:italic;font-size:18px;letter-spacing:.02em}
.tpl-c .ms-hero{padding:8px 30px 24px;gap:22px;align-items:stretch}
.tpl-c .ms-copy{flex:1;display:flex;flex-direction:column;justify-content:center;min-width:0}
.tpl-c .ms-eyebrow{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:#B5826F;font-weight:700;margin-bottom:14px}
.tpl-c h1{font-family:'Playfair Display',Georgia,serif;font-weight:500;font-size:50px;line-height:1;letter-spacing:-0.02em;margin:0;color:#2B1B1A}
.tpl-c h1 em{font-style:italic;color:#9B5C4A}
.tpl-c .ms-sub{margin:14px 0 22px;font-size:13px;line-height:1.55;color:#5a4946;max-width:32ch}
.tpl-c .ms-services{display:flex;gap:8px;margin:18px 0;flex-wrap:wrap}
.tpl-c .ms-services span{background:#fff;padding:7px 12px;border-radius:9999px;font-size:11px;font-weight:600;color:#2B1B1A;border:1px solid rgba(43,27,26,.08)}
.tpl-c .pill{display:inline-flex;align-items:center;gap:8px;background:#9B5C4A;color:#fff;padding:12px 20px;border-radius:9999px;font-size:12.5px;font-weight:700;width:fit-content}
.tpl-c .ms-img{flex:1;border-radius:18px;overflow:hidden;background:#D9B7A8 center/cover no-repeat url('https://images.unsplash.com/photo-1560066984-138dadb4c035?w=900&q=80');position:relative}
.tpl-c .ms-img::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(43,27,26,.18))}
.tpl-c .ms-tag{position:absolute;top:14px;right:14px;background:#fff;color:#2B1B1A;padding:7px 12px;border-radius:9999px;font-size:11px;font-weight:600;z-index:2}

/* --- D: TRADES (Bold) --- */
.tpl-d{background:#0F1722;color:#fff;position:relative}
.tpl-d::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 85% 15%,rgba(255,214,10,.18),transparent 50%)}
.tpl-d .ms-nav{color:#fff;padding:14px 28px;position:relative;z-index:2}
.tpl-d .ms-nav .brand{font-weight:800;letter-spacing:.05em;font-size:14px;display:flex;align-items:center;gap:8px}
.tpl-d .ms-nav .brand::before{content:'';width:22px;height:22px;border-radius:6px;background:#FFD60A;display:inline-block}
.tpl-d .ms-nav .links{color:rgba(255,255,255,.6)}
.tpl-d .ms-nav .phone{background:#FFD60A;color:#0F1722;padding:8px 14px;border-radius:8px;font-weight:800;font-size:12px}
.tpl-d .ms-hero{padding:8px 28px 24px;gap:24px;position:relative;z-index:2;align-items:center}
.tpl-d .ms-copy{flex:1.1;min-width:0}
.tpl-d .ms-eyebrow{display:inline-flex;align-items:center;gap:6px;background:rgba(255,214,10,.14);color:#FFD60A;padding:6px 11px;border-radius:9999px;font-size:10px;font-weight:700;letter-spacing:.16em;margin-bottom:14px}
.tpl-d .ms-eyebrow .ping{width:6px;height:6px;border-radius:50%;background:#FFD60A;box-shadow:0 0 8px #FFD60A}
.tpl-d h1{font-size:46px;font-weight:800;line-height:1.02;letter-spacing:-0.025em;margin:0;color:#fff}
.tpl-d h1 span{color:#FFD60A}
.tpl-d .ms-sub{margin:14px 0 20px;font-size:13px;color:rgba(255,255,255,.7);max-width:34ch;line-height:1.55}
.tpl-d .ms-ctas{display:flex;gap:10px;flex-wrap:wrap}
.tpl-d .pill{display:inline-flex;align-items:center;gap:8px;padding:12px 18px;border-radius:9999px;font-size:12.5px;font-weight:700}
.tpl-d .pill.yellow{background:#FFD60A;color:#0F1722}
.tpl-d .pill.ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.22)}
.tpl-d .ms-stats{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:8px;align-self:stretch;align-content:center}
.tpl-d .ms-stat{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:14px}
.tpl-d .ms-stat .n{font-size:26px;font-weight:800;color:#FFD60A;letter-spacing:-0.02em;line-height:1}
.tpl-d .ms-stat .l{font-size:10.5px;color:rgba(255,255,255,.6);margin-top:6px;letter-spacing:.04em}

/* --- E: FORGE (Basic — Personal Trainer) --- */
.tpl-e{background:#0E0F12;color:#fff;position:relative;overflow:hidden}
.tpl-e .ms-bg{position:absolute;inset:0;background:#1A1A1F center/cover no-repeat url('https://images.unsplash.com/photo-1581009146145-b5ef050c2e1e?w=1200&q=80')}
.tpl-e .ms-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(100deg,rgba(14,15,18,.94) 0%,rgba(14,15,18,.55) 60%,transparent 100%)}
.tpl-e .ms-nav{position:relative;z-index:2;color:#fff;padding:16px 32px}
.tpl-e .ms-nav .brand{font-weight:800;letter-spacing:.18em;font-size:13px;text-transform:uppercase}
.tpl-e .ms-nav .brand::before{content:'';width:14px;height:14px;background:#FF5A1F;display:inline-block;margin-right:8px;transform:rotate(45deg);vertical-align:middle}
.tpl-e .ms-nav .links{color:rgba(255,255,255,.65);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase}
.tpl-e .ms-hero{position:relative;z-index:2;padding:8px 32px 30px;flex-direction:column;justify-content:flex-end}
.tpl-e .ms-copy{max-width:60%}
.tpl-e .ms-eyebrow{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:#FF5A1F;font-weight:800;margin-bottom:14px;display:inline-block}
.tpl-e h1{font-size:54px;font-weight:900;line-height:.96;letter-spacing:-0.03em;margin:0;color:#fff;text-transform:uppercase}
.tpl-e h1 span{color:#FF5A1F}
.tpl-e .ms-sub{margin:16px 0 22px;font-size:13px;color:rgba(255,255,255,.7);max-width:38ch;line-height:1.55}
.tpl-e .pill{display:inline-flex;align-items:center;gap:8px;background:#FF5A1F;color:#0E0F12;padding:14px 22px;border-radius:0;font-size:12.5px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;clip-path:polygon(8px 0,100% 0,calc(100% - 8px) 100%,0 100%)}
.tpl-e .ms-stats{position:absolute;right:32px;bottom:32px;display:flex;flex-direction:column;gap:6px;text-align:right;z-index:2}
.tpl-e .ms-stats div{font-size:11px;color:rgba(255,255,255,.55);letter-spacing:.1em;text-transform:uppercase}
.tpl-e .ms-stats div b{display:block;font-size:24px;color:#fff;font-weight:900;letter-spacing:-0.02em;margin-bottom:2px}

/* --- F: VINCENT (Basic — Consultant 1-pager) --- */
.tpl-f{background:#F4F0E6;color:#0E1B2C;font-feature-settings:'liga' 1}
.tpl-f .ms-nav{padding:18px 36px;color:#0E1B2C;border-bottom:1px solid rgba(14,27,44,.08)}
.tpl-f .ms-nav .brand{font-family:'Playfair Display',Georgia,serif;font-weight:600;font-size:18px;letter-spacing:-0.01em}
.tpl-f .ms-nav .links{color:rgba(14,27,44,.55);font-size:11.5px}
.tpl-f .ms-hero{padding:0 36px;flex-direction:column;justify-content:center;align-items:flex-start}
.tpl-f .ms-copy{max-width:80%}
.tpl-f .ms-num{font-family:'Playfair Display',Georgia,serif;font-size:14px;color:#7C684A;font-style:italic;margin-bottom:18px;display:block}
.tpl-f h1{font-family:'Playfair Display',Georgia,serif;font-weight:500;font-size:62px;line-height:1.02;letter-spacing:-0.03em;margin:0;color:#0E1B2C;max-width:14ch}
.tpl-f h1 em{font-style:italic;color:#7C684A}
.tpl-f .ms-sub{margin:24px 0 28px;font-size:14px;line-height:1.6;color:#5a5849;max-width:42ch;font-weight:400}
.tpl-f .ms-row{display:flex;align-items:center;gap:18px}
.tpl-f .pill{display:inline-flex;align-items:center;gap:8px;background:#0E1B2C;color:#F4F0E6;padding:14px 22px;border-radius:0;font-size:12.5px;font-weight:600;letter-spacing:.04em}
.tpl-f .ms-meta{font-size:11.5px;color:rgba(14,27,44,.55);letter-spacing:.08em;text-transform:uppercase}
.tpl-f .ms-meta b{color:#0E1B2C;font-weight:600;display:block;margin-bottom:2px}

/* --- G: CRUST (Basic — Bakery 1-pager) --- */
.tpl-g{background:#F5EAD8;color:#3D2817;position:relative}
.tpl-g .ms-nav{padding:18px 32px;color:#3D2817}
.tpl-g .ms-nav .brand{font-family:'Playfair Display',Georgia,serif;font-style:italic;font-size:20px;color:#3D2817}
.tpl-g .ms-nav .brand::before{content:'※';margin-right:6px;color:#A66B3F}
.tpl-g .ms-nav .links{color:rgba(61,40,23,.6);font-size:11.5px}
.tpl-g .ms-hero{padding:0 32px 28px;gap:24px;align-items:stretch}
.tpl-g .ms-copy{flex:1;display:flex;flex-direction:column;justify-content:center;min-width:0}
.tpl-g .ms-eyebrow{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:#A66B3F;font-weight:700;margin-bottom:12px}
.tpl-g h1{font-family:'Playfair Display',Georgia,serif;font-weight:500;font-size:48px;line-height:1.02;letter-spacing:-0.02em;margin:0;color:#3D2817}
.tpl-g h1 em{font-style:italic;color:#A66B3F}
.tpl-g .ms-sub{margin:14px 0 18px;font-size:13px;line-height:1.55;color:#5b4534;max-width:30ch}
.tpl-g .ms-menu{display:flex;flex-direction:column;gap:6px;margin-bottom:18px;font-family:'Playfair Display',Georgia,serif}
.tpl-g .ms-menu .row{display:flex;align-items:baseline;font-size:14px;color:#3D2817;gap:8px}
.tpl-g .ms-menu .row .dots{flex:1;border-bottom:1px dotted rgba(61,40,23,.3);margin:0 4px;transform:translateY(-3px)}
.tpl-g .ms-menu .row b{font-weight:500}
.tpl-g .pill{display:inline-flex;align-items:center;gap:8px;background:#3D2817;color:#F5EAD8;padding:12px 20px;border-radius:9999px;font-size:12.5px;font-weight:600;width:fit-content}
.tpl-g .ms-img{flex:.85;border-radius:6px;background:#E0C9A6 center/cover no-repeat url('https://images.unsplash.com/photo-1509440159596-0249088772ff?w=900&q=80');position:relative}
.tpl-g .ms-stamp{position:absolute;top:14px;right:14px;background:#3D2817;color:#F5EAD8;font-family:'Playfair Display',Georgia,serif;font-style:italic;padding:6px 12px;border-radius:9999px;font-size:11.5px}

/* --- H: MERIDIAN (Starter — Law Firm) --- */
.tpl-h{background:#0A1830;color:#F0E6D2}
.tpl-h .ms-nav{padding:18px 36px;border-bottom:1px solid rgba(240,230,210,.1)}
.tpl-h .ms-nav .brand{font-family:'Playfair Display',Georgia,serif;font-weight:600;font-size:18px;letter-spacing:.02em;color:#F0E6D2}
.tpl-h .ms-nav .brand::before{content:'';display:inline-block;width:1.5px;height:18px;background:#C9A977;vertical-align:middle;margin-right:10px;transform:translateY(-1px)}
.tpl-h .ms-nav .links{color:rgba(240,230,210,.55);font-size:11.5px;letter-spacing:.06em}
.tpl-h .ms-hero{padding:6px 36px 28px;gap:30px}
.tpl-h .ms-copy{flex:1.1;display:flex;flex-direction:column;justify-content:center;min-width:0}
.tpl-h .ms-eyebrow{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:#C9A977;font-weight:700;margin-bottom:14px}
.tpl-h h1{font-family:'Playfair Display',Georgia,serif;font-weight:500;font-size:46px;line-height:1.06;letter-spacing:-0.02em;margin:0;color:#F0E6D2}
.tpl-h h1 em{font-style:italic;color:#C9A977}
.tpl-h .ms-sub{margin:18px 0 22px;font-size:13.5px;line-height:1.6;color:rgba(240,230,210,.7);max-width:36ch}
.tpl-h .pill{display:inline-flex;align-items:center;gap:8px;background:transparent;color:#F0E6D2;border:1px solid #C9A977;padding:12px 20px;border-radius:0;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;width:fit-content}
.tpl-h .ms-grid{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(240,230,210,.1);align-self:stretch;border:1px solid rgba(240,230,210,.1)}
.tpl-h .ms-grid div{background:#0A1830;padding:18px 16px}
.tpl-h .ms-grid b{display:block;font-family:'Playfair Display',Georgia,serif;font-size:18px;color:#F0E6D2;margin-bottom:4px;font-weight:500}
.tpl-h .ms-grid span{font-size:11px;color:rgba(240,230,210,.6);line-height:1.4}

/* --- I: STUDIO NORTH (Starter — Architecture/Portfolio) --- */
.tpl-i{background:#FAFAFA;color:#0A0A0A}
.tpl-i .ms-nav{padding:18px 36px;border-bottom:1px solid rgba(0,0,0,.08)}
.tpl-i .ms-nav .brand{font-weight:700;letter-spacing:.04em;font-size:14px;color:#0A0A0A}
.tpl-i .ms-nav .links{color:rgba(0,0,0,.55);font-size:11px;letter-spacing:.06em;text-transform:uppercase}
.tpl-i .ms-nav .ix{font-size:11px;color:rgba(0,0,0,.55);font-variant-numeric:tabular-nums}
.tpl-i .ms-hero{padding:0;flex-direction:column;align-items:stretch}
.tpl-i .ms-band{padding:28px 36px 24px;display:flex;align-items:flex-end;justify-content:space-between;gap:30px}
.tpl-i .ms-band h1{font-size:56px;font-weight:400;line-height:.95;letter-spacing:-0.04em;margin:0;color:#0A0A0A;max-width:14ch}
.tpl-i .ms-band h1 b{font-weight:800}
.tpl-i .ms-band .meta{font-size:11px;color:rgba(0,0,0,.55);max-width:24ch;line-height:1.5;letter-spacing:.02em}
.tpl-i .ms-work{flex:1;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(0,0,0,.08);min-height:0;margin-top:auto}
.tpl-i .ms-work div{background:center/cover no-repeat;position:relative;min-height:120px}
.tpl-i .ms-work div:nth-child(1){background-image:url('https://images.unsplash.com/photo-1503387762-592deb58ef4e?w=700&q=80');background-color:#7a857d}
.tpl-i .ms-work div:nth-child(2){background-image:url('https://images.unsplash.com/photo-1487958449943-2429e8be8625?w=700&q=80');background-color:#a0a39f}
.tpl-i .ms-work div:nth-child(3){background-image:url('https://images.unsplash.com/photo-1545324418-cc1a3fa10c00?w=700&q=80');background-color:#bdb6a8}
.tpl-i .ms-work div:nth-child(4){background-image:url('https://images.unsplash.com/photo-1493809842364-78817add7ffb?w=700&q=80');background-color:#7d7a73}
.tpl-i .ms-work div span{position:absolute;bottom:10px;left:12px;font-size:10.5px;color:#fff;background:rgba(0,0,0,.55);padding:4px 8px;letter-spacing:.04em}

/* --- J: POWERFIX (Premium — Auto Booking) --- */
.tpl-j{background:#0C1424;color:#fff}
.tpl-j .ms-nav{padding:16px 30px}
.tpl-j .ms-nav .brand{font-weight:900;letter-spacing:.06em;font-size:14px;color:#fff;display:flex;align-items:center;gap:8px}
.tpl-j .ms-nav .brand::before{content:'';width:22px;height:22px;background:#FF7A1F;border-radius:6px;clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%)}
.tpl-j .ms-nav .links{color:rgba(255,255,255,.55);font-size:11px;letter-spacing:.04em;text-transform:uppercase}
.tpl-j .ms-nav .phone{background:#FF7A1F;color:#0C1424;padding:8px 14px;border-radius:6px;font-weight:800;font-size:12px}
.tpl-j .ms-hero{padding:8px 30px 26px;gap:24px;align-items:stretch}
.tpl-j .ms-copy{flex:1;display:flex;flex-direction:column;justify-content:center;min-width:0}
.tpl-j .ms-eyebrow{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:#FF7A1F;font-weight:800;margin-bottom:12px}
.tpl-j h1{font-size:40px;font-weight:900;line-height:1;letter-spacing:-0.025em;margin:0;color:#fff;text-transform:uppercase}
.tpl-j h1 span{color:#FF7A1F}
.tpl-j .ms-sub{margin:14px 0 18px;font-size:13px;color:rgba(255,255,255,.65);max-width:34ch;line-height:1.55}
.tpl-j .ms-trust{display:flex;gap:18px;font-size:11px;color:rgba(255,255,255,.65)}
.tpl-j .ms-trust b{color:#fff;font-weight:700;display:block;font-size:15px;margin-bottom:2px}
.tpl-j .ms-booking{flex:1.1;background:#fff;color:#0C1424;border-radius:14px;padding:20px;align-self:stretch;display:flex;flex-direction:column;gap:14px}
.tpl-j .ms-booking .h{font-size:13px;font-weight:800;color:#0C1424;letter-spacing:.04em;text-transform:uppercase;display:flex;align-items:center;justify-content:space-between}
.tpl-j .ms-booking .h span{font-size:10px;color:#FF7A1F;letter-spacing:.1em}
.tpl-j .ms-booking .field{display:flex;flex-direction:column;gap:6px}
.tpl-j .ms-booking .field label{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:#6a7180;font-weight:700}
.tpl-j .ms-booking .chips{display:flex;gap:6px;flex-wrap:wrap}
.tpl-j .ms-booking .chip{padding:7px 11px;border-radius:8px;font-size:11px;font-weight:600;background:#F1F3F7;color:#3a4252;border:1px solid #E4E7EE}
.tpl-j .ms-booking .chip.on{background:#0C1424;color:#fff;border-color:#0C1424}
.tpl-j .ms-booking .slot{padding:7px 11px;border-radius:8px;font-size:11px;font-weight:600;background:#F1F3F7;color:#3a4252;border:1px solid #E4E7EE}
.tpl-j .ms-booking .slot.on{background:#FF7A1F;color:#fff;border-color:#FF7A1F}
.tpl-j .ms-booking .slot.off{opacity:.4;text-decoration:line-through}
.tpl-j .ms-booking .go{margin-top:auto;background:#FF7A1F;color:#0C1424;padding:12px;border-radius:10px;font-weight:800;font-size:12.5px;text-align:center;letter-spacing:.04em}

/* --- K: BRIGHT (Premium — Tutor Booking) --- */
.tpl-k{background:#F4F8FE;color:#0E1A33}
.tpl-k .ms-nav{padding:16px 30px;color:#0E1A33}
.tpl-k .ms-nav .brand{font-weight:800;font-size:15px;display:flex;align-items:center;gap:8px}
.tpl-k .ms-nav .brand::before{content:'★';color:#FFB627;font-size:18px}
.tpl-k .ms-nav .links{color:rgba(14,26,51,.6);font-size:11.5px}
.tpl-k .ms-nav .cta{background:#1F4FFF;color:#fff;padding:8px 14px;border-radius:8px;font-weight:700;font-size:11.5px}
.tpl-k .ms-hero{padding:6px 30px 24px;gap:22px;align-items:stretch}
.tpl-k .ms-copy{flex:1;display:flex;flex-direction:column;justify-content:center;min-width:0}
.tpl-k .ms-eyebrow{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:#1F4FFF;font-weight:800;margin-bottom:12px}
.tpl-k h1{font-size:42px;font-weight:800;line-height:1.04;letter-spacing:-0.025em;margin:0;color:#0E1A33}
.tpl-k h1 span{position:relative;display:inline-block;color:#1F4FFF}
.tpl-k h1 span::after{content:'';position:absolute;left:0;right:0;bottom:2px;height:8px;background:#FFB627;opacity:.4;z-index:-1}
.tpl-k .ms-sub{margin:14px 0 18px;font-size:13px;color:#475063;max-width:34ch;line-height:1.6}
.tpl-k .ms-tutors{display:flex;align-items:center;gap:8px;font-size:11.5px;color:#475063}
.tpl-k .ms-tutors .avs{display:flex}
.tpl-k .ms-tutors .av{width:26px;height:26px;border-radius:50%;background:#1F4FFF;border:2px solid #F4F8FE;margin-left:-8px;color:#fff;font-size:10px;font-weight:700;display:grid;place-items:center}
.tpl-k .ms-tutors .av:first-child{margin-left:0}
.tpl-k .ms-tutors .av:nth-child(2){background:#FFB627}
.tpl-k .ms-tutors .av:nth-child(3){background:#3DC084}
.tpl-k .ms-tutors .av:nth-child(4){background:#0E1A33}
.tpl-k .ms-sched{flex:1;background:#fff;border-radius:14px;padding:18px;align-self:stretch;display:flex;flex-direction:column;gap:10px;box-shadow:0 12px 30px rgba(14,26,51,.06)}
.tpl-k .ms-sched .h{display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:800;color:#0E1A33}
.tpl-k .ms-sched .h span{font-size:11px;color:#1F4FFF;font-weight:700}
.tpl-k .ms-sched .days{display:grid;grid-template-columns:repeat(5,1fr);gap:5px}
.tpl-k .ms-sched .day{text-align:center;padding:8px 4px;border-radius:8px;background:#F4F8FE;border:1px solid #E5ECF7}
.tpl-k .ms-sched .day .dn{font-size:9.5px;color:#7a8398;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.tpl-k .ms-sched .day .dd{font-size:15px;font-weight:800;color:#0E1A33;margin-top:2px}
.tpl-k .ms-sched .day.on{background:#1F4FFF;border-color:#1F4FFF}
.tpl-k .ms-sched .day.on .dn,.tpl-k .ms-sched .day.on .dd{color:#fff}
.tpl-k .ms-sched .times{display:flex;flex-wrap:wrap;gap:5px;margin-top:4px}
.tpl-k .ms-sched .time{padding:6px 10px;border-radius:6px;font-size:10.5px;font-weight:700;background:#F4F8FE;color:#475063;border:1px solid #E5ECF7}
.tpl-k .ms-sched .time.on{background:#0E1A33;color:#fff;border-color:#0E1A33}
.tpl-k .ms-sched .book{margin-top:auto;background:#FFB627;color:#0E1A33;padding:12px;border-radius:10px;text-align:center;font-weight:800;font-size:12px;letter-spacing:.04em}

/* --- L: SPARKLE (Premium — Cleaning Booking) --- */
.tpl-l{background:#E9F7F1;color:#0F2A22}
.tpl-l .ms-nav{padding:16px 30px;color:#0F2A22}
.tpl-l .ms-nav .brand{font-weight:800;font-size:15px;display:flex;align-items:center;gap:8px;letter-spacing:-0.01em}
.tpl-l .ms-nav .brand::before{content:'';width:18px;height:18px;border-radius:50%;background:#FFC93C;box-shadow:0 0 0 4px rgba(255,201,60,.25)}
.tpl-l .ms-nav .links{color:rgba(15,42,34,.6);font-size:11.5px}
.tpl-l .ms-nav .cta{background:#2BBF8C;color:#fff;padding:8px 14px;border-radius:9999px;font-weight:700;font-size:11.5px}
.tpl-l .ms-hero{padding:8px 30px 26px;gap:22px;align-items:stretch}
.tpl-l .ms-copy{flex:1.1;display:flex;flex-direction:column;justify-content:center;min-width:0}
.tpl-l .ms-eyebrow{display:inline-flex;align-items:center;gap:6px;font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:#0F2A22;font-weight:800;margin-bottom:12px;background:#FFC93C;padding:6px 11px;border-radius:9999px;width:fit-content}
.tpl-l h1{font-size:46px;font-weight:800;line-height:1;letter-spacing:-0.025em;margin:0;color:#0F2A22}
.tpl-l h1 span{color:#2BBF8C}
.tpl-l .ms-sub{margin:14px 0 16px;font-size:13px;color:#3a5048;max-width:34ch;line-height:1.55}
.tpl-l .ms-points{display:flex;gap:18px;font-size:11.5px;color:#3a5048}
.tpl-l .ms-points span::before{content:'✓ ';color:#2BBF8C;font-weight:800}
.tpl-l .ms-book{flex:1;background:#fff;border-radius:18px;padding:20px;align-self:stretch;display:flex;flex-direction:column;gap:14px;box-shadow:0 14px 32px rgba(15,42,34,.08)}
.tpl-l .ms-book .step{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:#7a8d86;font-weight:700}
.tpl-l .ms-book h4{margin:0;font-size:14px;font-weight:800;color:#0F2A22}
.tpl-l .ms-book .services{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.tpl-l .ms-book .svc{padding:10px;border-radius:10px;background:#F1F9F5;border:1px solid #DCEEE5;font-size:11px;font-weight:700;color:#0F2A22}
.tpl-l .ms-book .svc.on{background:#2BBF8C;color:#fff;border-color:#2BBF8C}
.tpl-l .ms-book .svc small{display:block;font-size:9.5px;color:rgba(15,42,34,.55);font-weight:600;margin-top:2px;text-transform:uppercase;letter-spacing:.06em}
.tpl-l .ms-book .svc.on small{color:rgba(255,255,255,.7)}
.tpl-l .ms-book .cal{display:flex;gap:5px;flex-wrap:wrap}
.tpl-l .ms-book .cal .d{padding:7px 10px;border-radius:8px;font-size:10.5px;font-weight:700;background:#F1F9F5;color:#3a5048;border:1px solid #DCEEE5;text-align:center;min-width:42px}
.tpl-l .ms-book .cal .d.on{background:#0F2A22;color:#fff;border-color:#0F2A22}
.tpl-l .ms-book .cal .d small{display:block;font-size:8.5px;letter-spacing:.06em;text-transform:uppercase;opacity:.7;font-weight:700;margin-bottom:2px}
.tpl-l .ms-book .go{margin-top:auto;background:#FFC93C;color:#0F2A22;padding:12px;border-radius:12px;text-align:center;font-weight:800;font-size:12.5px}

/* --- C: LUSH booking enhancement (Premium) --- */
.tpl-c .ms-booking{
  flex:1;background:#fff;border-radius:16px;padding:18px;align-self:stretch;
  display:flex;flex-direction:column;gap:10px;box-shadow:0 12px 30px rgba(43,27,26,.1);
}
.tpl-c .ms-booking h4{margin:0;font-family:'Playfair Display',Georgia,serif;font-size:18px;font-weight:600;color:#2B1B1A}
.tpl-c .ms-booking .label{font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:#9B5C4A;font-weight:700}
.tpl-c .ms-booking .slots{display:grid;grid-template-columns:repeat(3,1fr);gap:5px}
.tpl-c .ms-booking .slot{padding:9px 6px;border-radius:8px;text-align:center;font-size:10.5px;font-weight:700;background:#F6E6E0;color:#2B1B1A;border:1px solid rgba(43,27,26,.08)}
.tpl-c .ms-booking .slot.on{background:#9B5C4A;color:#fff;border-color:#9B5C4A}
.tpl-c .ms-booking .slot.off{opacity:.4;text-decoration:line-through}
.tpl-c .ms-booking .go{margin-top:auto;background:#9B5C4A;color:#fff;padding:12px;border-radius:9999px;text-align:center;font-weight:700;font-size:12px;letter-spacing:.04em}

/* ============ CHAT WIDGET ============ */
.chat-widget{
  position:fixed;bottom:24px;right:24px;z-index:200;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
.chat-toggle{
  width:56px;height:56px;border-radius:16px;
  background:linear-gradient(135deg,var(--brand-blue) 0%,var(--brand-blue-mid) 100%);
  box-shadow:0 8px 32px rgba(0,17,255,0.4),0 0 0 1px rgba(255,255,255,0.08) inset;
  display:grid;place-items:center;color:#fff;
  border:none;cursor:pointer;
  transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s;
  position:relative;
}
.chat-toggle:hover{transform:scale(1.06);box-shadow:0 12px 40px rgba(0,17,255,0.5),0 0 0 1px rgba(255,255,255,0.12) inset}
.chat-toggle:active{transform:scale(0.98)}
.chat-toggle[data-state="open"] .chat-icon{display:none}
.chat-toggle[data-state="open"] .chat-icon-close{display:block}
.chat-icon{width:24px;height:24px;display:block}
.chat-icon-close{width:24px;height:24px;display:none}
.chat-badge{
  position:absolute;top:-4px;right:-4px;
  min-width:20px;height:20px;border-radius:9999px;
  background:var(--accent-cyan);color:#000;
  font-size:11px;font-weight:700;line-height:20px;text-align:center;padding:0 6px;
  display:none;align-items:center;justify-content:center;
  animation:pulse 2s infinite;
  box-shadow:0 0 0 2px var(--bg-black),0 0 12px var(--accent-cyan);
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.6}}

.chat-window{
  position:absolute;bottom:72px;right:0;
  width:380px;max-width:calc(100vw - 48px);
  height:520px;max-height:calc(100vh - 120px);
  background:var(--bg-black-2);
  border:1px solid var(--hairline);
  border-radius:16px;
  box-shadow:0 24px 64px rgba(0,0,0,0.6),0 0 0 1px rgba(255,255,255,0.04) inset;
  display:flex;flex-direction:column;
  opacity:0;visibility:hidden;transform:translateY(16px) scale(0.96);
  transition:opacity .2s,visibility .2s,transform .2s cubic-bezier(.34,1.56,.64,1);
  overflow:hidden;
}
.chat-widget[data-state="open"] .chat-window{
  opacity:1;visibility:visible;transform:translateY(0) scale(1);
}
.chat-header{
  display:flex;align-items:center;gap:12px;
  padding:16px 20px;
  background:rgba(255,255,255,0.02);
  border-bottom:1px solid var(--hairline);
}
.chat-avatar{
  width:36px;height:36px;border-radius:10px;
  background:linear-gradient(135deg,var(--brand-blue) 0%,var(--accent-cyan) 100%);
  display:grid;place-items:center;flex-shrink:0;
}
.chat-avatar svg{width:20px;height:20px;stroke:#fff}
.chat-title{flex:1;min-width:0}
.chat-title strong{display:block;font-size:15px;font-weight:700;color:#fff;line-height:1.2}
.chat-title span{font-size:11px;color:var(--text-grey-soft);letter-spacing:0.02em}
.chat-minimize{
  width:32px;height:32px;border-radius:8px;
  background:rgba(255,255,255,0.06);border:1px solid var(--hairline);
  color:var(--text-grey);font-size:20px;line-height:1;
  transition:background .15s,color .15s;
}
.chat-minimize:hover{background:rgba(255,255,255,0.12);color:#fff}

.chat-messages{
  flex:1;overflow-y:auto;padding:16px;
  display:flex;flex-direction:column;gap:12px;
  scroll-behavior:smooth;
}
.chat-message{
  display:flex;gap:10px;max-width:85%;
  animation:fadeUp .3s ease;
}
.chat-message.assistant{align-self:flex-start}
.chat-message.user{align-self:flex-end;flex-direction:row-reverse}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.msg-avatar{
  width:28px;height:28px;border-radius:8px;flex-shrink:0;
  display:grid;place-items:center;
}
.chat-message.assistant .msg-avatar{
  background:linear-gradient(135deg,var(--brand-blue) 0%,var(--accent-cyan) 100%);
}
.chat-message.user .msg-avatar{
  background:rgba(255,255,255,0.08);border:1px solid var(--hairline);
}
.msg-avatar svg{width:16px;height:16px;stroke:#fff}
.msg-bubble{
  padding:12px 16px;border-radius:14px;
  font-size:14px;line-height:1.5;
  max-width:100%;
}
.chat-message.assistant .msg-bubble{
  background:var(--surface-card);
  border:1px solid var(--hairline);
  border-bottom-left-radius:4px;
  color:#fff;
}
.chat-message.user .msg-bubble{
  background:linear-gradient(135deg,var(--brand-blue) 0%,var(--brand-blue-mid) 100%);
  border-bottom-right-radius:4px;
  color:#fff;
  box-shadow:0 4px 16px rgba(0,17,255,0.3);
}
.msg-bubble p{margin:0 0 8px}
.msg-bubble p:last-child{margin:0}
.msg-bubble ul{margin:8px 0 0;padding-left:18px}
.msg-bubble li{margin:4px 0}

.chat-typing{
  display:none;align-items:center;gap:10px;
  padding:0 16px 16px;color:var(--text-grey-soft);
  font-size:13px;
}
.typing-dots{display:flex;gap:3px}
.typing-dots span{
  width:6px;height:6px;border-radius:50%;
  background:var(--accent-cyan);
  animation:typing 1.4s infinite ease-in-out;
}
.typing-dots span:nth-child(2){animation-delay:.2s}
.typing-dots span:nth-child(3){animation-delay:.4s}
@keyframes typing{0%,80%,100%{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}

.chat-input{
  display:flex;gap:10px;padding:16px;
  background:rgba(255,255,255,0.02);
  border-top:1px solid var(--hairline);
}
.chat-input input{
  flex:1;padding:12px 16px;border-radius:9999px;
  background:var(--surface-card);border:1px solid var(--hairline);
  color:#fff;font-size:14px;font-family:inherit;
  outline:none;transition:border .15s,box-shadow .15s;
}
.chat-input input::placeholder{color:var(--text-grey-soft)}
.chat-input input:focus{border-color:var(--brand-blue);box-shadow:0 0 0 3px rgba(0,17,255,0.2)}
.chat-input button{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--brand-blue) 0%,var(--brand-blue-mid) 100%);
  color:#fff;display:grid;place-items:center;
  transition:transform .15s,box-shadow .15s;
}
.chat-input button:hover{transform:scale(1.05);box-shadow:0 4px 16px rgba(0,17,255,0.4)}
.chat-input button:active{transform:scale(0.95)}
.chat-input button svg{width:20px;height:20px}

.chat-suggestions{
  display:flex;flex-wrap:wrap;gap:8px;padding:0 16px 16px;
}
.suggestion-chip{
  padding:8px 14px;border-radius:9999px;
  background:var(--surface-card);border:1px solid var(--hairline);
  color:var(--text-grey);font-size:12px;font-weight:500;font-family:inherit;
  cursor:pointer;transition:background .15s,border .15s,color .15s;
  white-space:nowrap;
}
.suggestion-chip:hover{background:var(--brand-blue);border-color:var(--brand-blue);color:#fff}

/* Mobile adjustments */
@media (max-width:480px){
  .chat-widget{bottom:16px;right:16px;left:16px}
  .chat-window{width:100%;height:calc(100vh - 100px);max-height:none;bottom:72px;right:0;left:0;border-radius:16px 16px 0 0}
  .chat-toggle{width:52px;height:52px}
}
