/* ================================================================
   MSB CIO SLIDES — Design System
   Inspired by AgiBot & WeBank consulting deck aesthetics
   Brand: MSB Orange (#F96618) + Dark Premium Theme
   ================================================================ */

/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* MSB Brand Palette */
  --bg:#0a0a0f;--bg2:#12121a;--bg3:#1a1a2e;
  --primary:#F96618;--accent:#FFAB40;--success:#10B981;--danger:#EF4444;--purple:#8B5CF6;--cyan:#00AEC7;
  --text:#F1F5F9;--muted:#94A3B8;--dim:#64748B;
  --glass:rgba(255,255,255,0.04);--glass-border:rgba(255,255,255,0.08);
  /* Slide Dimensions */
  --slide-h:100vh;--slide-h:100dvh;
  /* Spacing Scale */
  --sp-xs:4px;--sp-sm:8px;--sp-md:16px;--sp-lg:24px;--sp-xl:32px;--sp-2xl:48px;--sp-3xl:64px;
  /* Radius Scale */
  --r-sm:6px;--r-md:12px;--r-lg:16px;--r-xl:20px;--r-full:9999px;
  /* Shadow Scale */
  --shadow-sm:0 2px 8px rgba(0,0,0,.2);
  --shadow-md:0 8px 32px rgba(0,0,0,.3);
  --shadow-lg:0 12px 40px rgba(0,0,0,.35);
  --shadow-glow-primary:0 0 20px rgba(249,102,24,.15);
  --shadow-glow-accent:0 0 20px rgba(255,171,64,.15);
  /* Transition */
  --ease-out:cubic-bezier(.4,0,.2,1);
  --duration:0.3s;
}
html{scroll-snap-type:y mandatory;scroll-behavior:smooth;overflow-x:hidden}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden}
h1,h2,h3,h4,h5,h6{font-family:'Montserrat',sans-serif;font-weight:700;line-height:1.2}


/* ================================================================
   PROGRESS BAR
   ================================================================ */
#progress-bar{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--cyan),var(--accent));z-index:9999;transition:width .3s ease;width:0}


/* ================================================================
   SLIDE COUNTER
   ================================================================ */
#slide-counter{position:fixed;bottom:24px;right:32px;font-family:'Montserrat',sans-serif;font-size:14px;font-weight:600;color:var(--muted);z-index:9998;background:rgba(10,10,15,.7);backdrop-filter:blur(8px);padding:6px 14px;border-radius:20px;border:1px solid var(--glass-border)}
#slide-counter .current{color:var(--accent);font-size:18px}


/* ================================================================
   NAV HINT
   ================================================================ */
#nav-hint{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);font-size:12px;color:var(--dim);z-index:9998;opacity:1;transition:opacity 2s ease 5s;pointer-events:none}


/* ================================================================
   SLIDES — Core Layout
   ================================================================ */
.slide{min-height:var(--slide-h);scroll-snap-align:start;scroll-snap-stop:always;display:flex;align-items:center;justify-content:center;padding:36px 60px;position:relative;overflow:hidden}
.slide-inner{max-width:1400px;width:100%;position:relative;z-index:2}


/* ================================================================
   ANIMATION — Reveal System
   ================================================================ */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}.reveal-delay-5{transition-delay:.5s}.reveal-delay-6{transition-delay:.6s}
.reveal-delay-7{transition-delay:.7s}.reveal-delay-8{transition-delay:.8s}.reveal-delay-9{transition-delay:.9s}

/* Slide-in from left */
.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity .7s ease,transform .7s ease}
.reveal-left.visible{opacity:1;transform:translateX(0)}

/* Slide-in from right */
.reveal-right{opacity:0;transform:translateX(40px);transition:opacity .7s ease,transform .7s ease}
.reveal-right.visible{opacity:1;transform:translateX(0)}

/* Scale-up entrance */
.reveal-scale{opacity:0;transform:scale(.85);transition:opacity .7s ease,transform .7s ease}
.reveal-scale.visible{opacity:1;transform:scale(1)}

/* Stagger children with CSS counters */
.stagger-children > *{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}
.stagger-children.visible > *{opacity:1;transform:translateY(0)}
.stagger-children.visible > *:nth-child(1){transition-delay:.05s}
.stagger-children.visible > *:nth-child(2){transition-delay:.1s}
.stagger-children.visible > *:nth-child(3){transition-delay:.15s}
.stagger-children.visible > *:nth-child(4){transition-delay:.2s}
.stagger-children.visible > *:nth-child(5){transition-delay:.25s}
.stagger-children.visible > *:nth-child(6){transition-delay:.3s}
.stagger-children.visible > *:nth-child(7){transition-delay:.35s}
.stagger-children.visible > *:nth-child(8){transition-delay:.4s}
.stagger-children.visible > *:nth-child(9){transition-delay:.45s}
.stagger-children.visible > *:nth-child(10){transition-delay:.5s}


/* ================================================================
   TYPOGRAPHY
   ================================================================ */
.slide-title{font-size:clamp(28px,3.5vw,48px);font-weight:800;margin-bottom:8px;background:linear-gradient(135deg,var(--text),var(--muted));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.slide-title.accent-title{background:linear-gradient(135deg,var(--accent),#fbbf24);-webkit-background-clip:text;background-clip:text}
.slide-title.primary-title{background:linear-gradient(135deg,var(--primary),var(--cyan));-webkit-background-clip:text;background-clip:text}
.slide-subtitle{font-size:clamp(14px,1.5vw,20px);color:var(--muted);font-weight:400;margin-bottom:40px}
.section-label{font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:12px;display:inline-block}

/* Large emphasis text */
.text-hero{font-family:'Montserrat',sans-serif;font-size:clamp(36px,5vw,72px);font-weight:900;line-height:1.05}
.text-stat{font-family:'Montserrat',sans-serif;font-size:clamp(28px,3.5vw,48px);font-weight:800;line-height:1}
.text-label{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase}

/* Gradient text utility */
.gradient-text{background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.gradient-text-cool{background:linear-gradient(135deg,var(--cyan),var(--purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}


/* ================================================================
   CARDS — Glass Morphism Base
   ================================================================ */
.card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:var(--sp-lg);backdrop-filter:blur(12px);transition:transform var(--duration) var(--ease-out),box-shadow var(--duration) var(--ease-out),border-color var(--duration) var(--ease-out)}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:rgba(255,255,255,.12)}

/* Elevated card variant */
.card-elevated{background:linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.1);border-radius:var(--r-lg);padding:var(--sp-lg);backdrop-filter:blur(16px);box-shadow:var(--shadow-sm)}
.card-elevated:hover{box-shadow:var(--shadow-md);border-color:rgba(255,255,255,.15)}


/* ================================================================
   TABLES — Data Display
   ================================================================ */
.data-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px;border-radius:var(--r-md);overflow:hidden}
.data-table thead th{background:rgba(249,102,24,.15);color:var(--primary);font-weight:600;padding:12px 16px;text-align:left;font-size:13px;letter-spacing:.5px;border-bottom:2px solid rgba(249,102,24,.3)}
.data-table tbody td{padding:10px 16px;border-bottom:1px solid var(--glass-border)}
.data-table tbody tr{transition:background .2s}
.data-table tbody tr:nth-child(even){background:rgba(255,255,255,.02)}
.data-table tbody tr:hover{background:rgba(249,102,24,.08)}
.data-table .highlight-row{background:rgba(255,171,64,.08)!important;font-weight:600}
.data-table .highlight-col{color:var(--accent);font-weight:700}


/* ================================================================
   TAGS — Inline Labels
   ================================================================ */
.tag{display:inline-block;padding:3px 10px;border-radius:var(--r-full);font-size:11px;font-weight:600;margin:2px}
.tag-blue{background:rgba(249,102,24,.15);color:var(--primary)}
.tag-green{background:rgba(16,185,129,.15);color:var(--success)}
.tag-red{background:rgba(239,68,68,.15);color:var(--danger)}
.tag-amber{background:rgba(255,171,64,.15);color:var(--accent)}
.tag-purple{background:rgba(139,92,246,.15);color:var(--purple)}
.tag-cyan{background:rgba(6,182,212,.15);color:var(--cyan)}


/* ================================================================
   GLOW & SPECIAL EFFECTS
   ================================================================ */
.glow-border{border:1px solid rgba(255,171,64,.3);box-shadow:0 0 20px rgba(255,171,64,.1)}
.glow-primary{box-shadow:0 0 24px rgba(249,102,24,.15),0 0 48px rgba(249,102,24,.05)}
.glow-success{box-shadow:0 0 24px rgba(16,185,129,.15),0 0 48px rgba(16,185,129,.05)}

/* Shimmer effect for premium elements */
@keyframes shimmer{
  0%{background-position:-200% center}
  100%{background-position:200% center}
}
.shimmer{background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.04) 50%,transparent 100%);background-size:200% 100%;animation:shimmer 3s ease-in-out infinite}


/* ================================================================
   SLIDE BACKGROUND IMAGES
   ================================================================ */
.slide-bg-img{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;opacity:.18;pointer-events:none}
.slide-bg-img::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,var(--bg) 0%,transparent 30%,transparent 70%,var(--bg) 100%)}


/* ================================================================
   SLIDE 1: COVER — Curved Overlay + Background Image (WeBank)
   ================================================================ */
#slide-cover{padding:0;overflow:hidden;background:var(--bg)}
#slide-cover .cover-bg{position:absolute;top:0;right:0;width:60%;height:100%;background:url('images/01_cover_hero.png') center/cover no-repeat;z-index:0}
#slide-cover .cover-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,var(--bg) 0%,rgba(10,10,15,.6) 40%,rgba(10,10,15,.3) 100%)}
#slide-cover .cover-curved{position:absolute;top:0;left:0;width:50%;height:100%;z-index:1;overflow:hidden}
#slide-cover .cover-curved::before{
  content:'';position:absolute;top:0;left:0;width:130%;height:100%;
  background:linear-gradient(160deg,var(--bg) 0%,#12121a 40%,rgba(249,102,24,.15) 80%,rgba(249,102,24,.3) 100%);
  border-radius:0 0 50% 0;
  animation:coverGradient 8s ease-in-out infinite alternate;
}
@keyframes coverGradient{
  0%{background:linear-gradient(160deg,var(--bg) 0%,#12121a 40%,rgba(249,102,24,.15) 80%,rgba(249,102,24,.3) 100%)}
  100%{background:linear-gradient(160deg,var(--bg) 0%,#12121a 40%,rgba(139,92,246,.12) 80%,rgba(0,174,199,.25) 100%)}
}
#slide-cover .cover-content{position:relative;z-index:3;padding:80px;display:flex;flex-direction:column;justify-content:center;height:var(--slide-h);max-width:600px}
.cover-logo{font-family:'Montserrat',sans-serif;font-size:16px;font-weight:800;letter-spacing:8px;color:var(--accent);margin-bottom:32px}
.cover-divider{width:80px;height:2px;background:linear-gradient(90deg,var(--primary),var(--accent));margin:20px 0}
.cover-title{font-family:'Montserrat',sans-serif;font-size:clamp(32px,4.5vw,56px);font-weight:900;line-height:1.08;margin-bottom:16px;color:var(--text)}
.cover-title span{background:linear-gradient(135deg,var(--primary),var(--cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.cover-subtitle{font-size:clamp(16px,2vw,22px);color:var(--muted);font-weight:400;margin-bottom:32px}
.cover-meta{font-size:13px;color:var(--dim);line-height:2}
.cover-meta .confidential{color:var(--danger);font-weight:700;letter-spacing:2px;font-size:11px}
/* Floating particles on cover */
#cover-canvas{position:absolute;inset:0;z-index:2;pointer-events:none}


/* ================================================================
   NEW: Cover Curved Overlay Variants (WeBank style)
   ================================================================ */
.cover-curved{position:absolute;top:0;left:0;width:45%;height:100%;z-index:1;overflow:hidden}
.cover-curved::before{
  content:'';position:absolute;top:0;left:0;width:130%;height:100%;
  background:linear-gradient(160deg,var(--bg) 0%,var(--bg2) 40%,rgba(249,102,24,.15) 80%,rgba(249,102,24,.3) 100%);
  border-radius:0 0 50% 0;
}
.cover-image-side{position:absolute;top:0;right:0;width:55%;height:100%;background-size:cover;background-position:center;z-index:0}
.cover-image-side::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,var(--bg) 0%,rgba(10,10,15,.5) 30%,rgba(10,10,15,.2) 100%)}


/* ================================================================
   SLIDE 2: EXEC SUMMARY — Numbered Circle Badges (AgiBot)
   ================================================================ */
.exec-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:20px}
.exec-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:24px 20px;text-align:center;backdrop-filter:blur(12px);transition:transform var(--duration) var(--ease-out),box-shadow var(--duration) var(--ease-out)}
.exec-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.exec-circle{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Montserrat',sans-serif;font-size:20px;font-weight:800;color:#fff;margin:0 auto 16px;position:relative}
.exec-circle::after{content:'';position:absolute;inset:-3px;border-radius:50%;border:2px solid transparent;background:linear-gradient(135deg,var(--primary),var(--accent)) border-box;-webkit-mask:linear-gradient(#fff 0 0) padding-box,linear-gradient(#fff 0 0);-webkit-mask-composite:destination-out;mask-composite:exclude;opacity:.5}
.exec-card h4{font-size:14px;margin-bottom:10px}
.exec-card .metric-big{font-family:'Montserrat',sans-serif;font-size:clamp(22px,2.5vw,30px);font-weight:800;line-height:1.1;margin-bottom:6px}
.exec-card .desc{font-size:12px;color:var(--dim);line-height:1.4}


/* ================================================================
   NEW: Numbered Circle Badges — Reusable (AgiBot style)
   ================================================================ */
.num-badge{
  width:56px;height:56px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  font-family:'Montserrat',sans-serif;font-size:20px;font-weight:800;color:#fff;
  position:relative;flex-shrink:0;
}
.num-badge::after{
  content:'';position:absolute;inset:-3px;border-radius:50%;
  border:2px solid transparent;
  background:linear-gradient(135deg,var(--primary),var(--accent)) border-box;
  -webkit-mask:linear-gradient(#fff 0 0) padding-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:destination-out;mask-composite:exclude;
  opacity:.6;
}
.num-badge-sm{
  width:32px;height:32px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  font-family:'Montserrat',sans-serif;font-size:13px;font-weight:800;color:#fff;
  position:relative;flex-shrink:0;
}
.num-badge-sm::after{
  content:'';position:absolute;inset:-2px;border-radius:50%;
  border:2px solid transparent;
  background:linear-gradient(135deg,var(--primary),var(--accent)) border-box;
  -webkit-mask:linear-gradient(#fff 0 0) padding-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:destination-out;mask-composite:exclude;
  opacity:.5;
}


/* ================================================================
   SLIDE 3: GLOBAL MARKET — Metric Circles + Bar Chart
   ================================================================ */
.metric-circles{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:32px}
.metric-circle{text-align:center;position:relative}
.metric-circle .ring{width:110px;height:110px;border-radius:50%;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;flex-direction:column;position:relative}
.metric-circle .ring::before{content:'';position:absolute;inset:0;border-radius:50%;border:3px solid var(--glass-border)}
.metric-circle .ring::after{content:'';position:absolute;inset:0;border-radius:50%;border:3px solid transparent;border-top-color:var(--primary);border-right-color:var(--primary);animation:ringPulse 3s ease-in-out infinite}
@keyframes ringPulse{0%,100%{opacity:.4}50%{opacity:1}}
.metric-circle .ring .val{font-family:'Montserrat',sans-serif;font-size:22px;font-weight:800;line-height:1}
.metric-circle .ring .sub{font-size:10px;color:var(--dim);margin-top:2px}
.metric-circle .lbl{font-size:12px;color:var(--muted)}
.market-bar-chart{display:flex;flex-direction:column;gap:10px}
.market-bar-row{display:flex;align-items:center;gap:12px}
.market-bar-label{width:130px;font-size:13px;color:var(--muted);text-align:right;flex-shrink:0}
.market-bar-track{flex:1;height:30px;background:rgba(255,255,255,.04);border-radius:var(--r-sm);overflow:hidden;position:relative}
.market-bar-fill{height:100%;border-radius:var(--r-sm);display:flex;align-items:center;padding-left:12px;font-size:12px;font-weight:600;color:#fff;width:0;transition:width 1.2s var(--ease-out)}
.market-bar-row.highlighted .market-bar-label{color:var(--accent);font-weight:700}
.market-bar-row.highlighted .market-bar-fill{box-shadow:0 0 16px rgba(255,171,64,.3)}


/* ================================================================
   NEW: Metric Ring — SVG-based Progress (WeBank KPI)
   ================================================================ */
.metric-ring{
  width:120px;height:120px;position:relative;
  display:inline-flex;align-items:center;justify-content:center;
}
.metric-ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.metric-ring svg circle{fill:none;stroke-linecap:round}
.metric-ring svg .ring-bg{stroke:var(--glass-border);stroke-width:4}
.metric-ring svg .ring-fill{stroke:var(--primary);stroke-width:4;transition:stroke-dashoffset 1.5s var(--ease-out)}
.metric-ring .ring-value{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  font-family:'Montserrat',sans-serif;font-size:24px;font-weight:800;line-height:1;
}
.metric-ring .ring-label{font-size:11px;color:var(--muted);margin-top:4px;font-weight:400}


/* ================================================================
   SLIDE 4: INFLECTION — Before/After Split
   ================================================================ */
.inflection-split{display:grid;grid-template-columns:1fr auto 1fr;gap:0;min-height:400px}
.inflection-col{padding:28px 32px}
.inflection-col.before-col{background:rgba(239,68,68,.04);border-radius:var(--r-lg) 0 0 var(--r-lg);border:1px solid rgba(239,68,68,.12);border-right:none}
.inflection-col.after-col{background:rgba(16,185,129,.04);border-radius:0 var(--r-lg) var(--r-lg) 0;border:1px solid rgba(16,185,129,.12);border-left:none}
.inflection-divider{width:60px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;background:linear-gradient(180deg,rgba(239,68,68,.08),var(--bg),rgba(16,185,129,.08));z-index:1}
.inflection-divider::before{content:'';position:absolute;top:0;bottom:0;left:50%;width:2px;background:linear-gradient(180deg,var(--danger),var(--accent),var(--success));transform:translateX(-50%)}
.inflection-divider .year{font-family:'Montserrat',sans-serif;font-size:18px;font-weight:900;color:var(--accent);background:var(--bg);padding:12px 0;position:relative;z-index:1}
.inflection-item{display:flex;gap:10px;align-items:flex-start;margin-bottom:14px}
.inflection-item .icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;margin-top:1px}
.inflection-item .icon.bad{background:rgba(239,68,68,.15);color:var(--danger)}
.inflection-item .icon.good{background:rgba(16,185,129,.15);color:var(--success)}
.inflection-item .content{font-size:13px;color:var(--muted);line-height:1.5}
.inflection-item .content strong{color:var(--text)}
.inflection-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:24px}
.inflection-metric{text-align:center;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--r-md);padding:14px 8px}
.inflection-metric .val{font-family:'Montserrat',sans-serif;font-size:22px;font-weight:800;line-height:1}
.inflection-metric .lbl{font-size:11px;color:var(--muted);margin-top:4px}


/* ================================================================
   NEW: Split Layout — Reusable Before/After Comparison
   ================================================================ */
.split-layout{display:grid;grid-template-columns:1fr auto 1fr;gap:0;min-height:300px}
.split-left{background:rgba(239,68,68,.04);border-radius:var(--r-lg) 0 0 var(--r-lg);border:1px solid rgba(239,68,68,.12);border-right:none;padding:var(--sp-lg) var(--sp-xl)}
.split-right{background:rgba(16,185,129,.04);border-radius:0 var(--r-lg) var(--r-lg) 0;border:1px solid rgba(16,185,129,.12);border-left:none;padding:var(--sp-lg) var(--sp-xl)}
.split-divider{
  width:60px;display:flex;flex-direction:column;align-items:center;justify-content:center;
  position:relative;background:linear-gradient(180deg,rgba(239,68,68,.06),var(--bg),rgba(16,185,129,.06));
}
.split-divider::before{content:'';position:absolute;top:0;bottom:0;left:50%;width:2px;background:linear-gradient(180deg,var(--danger),var(--accent),var(--success));transform:translateX(-50%)}
.split-divider .label{
  font-family:'Montserrat',sans-serif;font-size:16px;font-weight:800;
  color:var(--accent);background:var(--bg);padding:10px 0;position:relative;z-index:1;
}


/* ================================================================
   SLIDE 5: VENDOR LANDSCAPE — Product Grid Cards (AgiBot)
   ================================================================ */
.vendor-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.vendor-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:20px 16px;text-align:center;backdrop-filter:blur(12px);transition:transform var(--duration) var(--ease-out),box-shadow var(--duration) var(--ease-out);position:relative;overflow:hidden}
.vendor-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.vendor-card.recommended{border:2px solid var(--accent);box-shadow:0 0 30px rgba(255,171,64,.15)}
.vendor-card .rank{position:absolute;top:12px;left:12px;font-family:'Montserrat',sans-serif;font-size:14px;font-weight:800;color:var(--accent);opacity:.6}
.vendor-silhouette{width:64px;height:80px;margin:8px auto 12px;border-radius:var(--r-md);background:linear-gradient(135deg,rgba(255,255,255,.04),rgba(255,255,255,.01));display:flex;align-items:center;justify-content:center;font-size:36px;opacity:.4}
.vendor-card .robot-name{font-family:'Montserrat',sans-serif;font-size:15px;font-weight:700;margin-bottom:4px}
.vendor-card .country-tag{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600;margin-bottom:10px}
.vendor-card .price{font-size:14px;font-weight:700;color:var(--success);margin-bottom:10px}
.vendor-card .score-ring{width:52px;height:52px;border-radius:50%;margin:0 auto;position:relative;display:flex;align-items:center;justify-content:center}
.vendor-card .score-ring .score-text{font-family:'Montserrat',sans-serif;font-size:16px;font-weight:800;position:relative;z-index:1}
.vendor-card .score-ring svg{position:absolute;inset:0;transform:rotate(-90deg)}
.vendor-card .score-ring svg circle{fill:none;stroke-width:3;stroke-linecap:round}
.vendor-card .ai-level{font-size:11px;color:var(--dim);margin-top:8px}
.vendor-card .avail{margin-top:6px}


/* ================================================================
   NEW: Product Grid Cards — Reusable (AgiBot style)
   ================================================================ */
.product-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}
.product-card{
  background:var(--glass);border:1px solid var(--glass-border);
  border-radius:var(--r-lg);padding:var(--sp-lg);text-align:center;
  backdrop-filter:blur(12px);transition:transform var(--duration) var(--ease-out),box-shadow var(--duration) var(--ease-out);
  position:relative;overflow:hidden;
}
.product-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.product-card.recommended{border:2px solid var(--accent);box-shadow:var(--shadow-glow-accent)}
.product-card.recommended::before{
  content:'RECOMMENDED';position:absolute;top:12px;right:-28px;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  color:#fff;font-size:9px;font-weight:700;letter-spacing:1px;
  padding:4px 36px;transform:rotate(45deg);
}
.product-card .product-image{
  width:80px;height:80px;margin:0 auto var(--sp-md);
  border-radius:var(--r-md);background:linear-gradient(135deg,rgba(255,255,255,.04),rgba(255,255,255,.01));
  display:flex;align-items:center;justify-content:center;font-size:40px;opacity:.5;
}
.product-card .product-name{font-family:'Montserrat',sans-serif;font-size:16px;font-weight:700;margin-bottom:4px}
.product-card .product-specs{font-size:12px;color:var(--muted);line-height:1.5;margin-bottom:12px}
.product-card .product-score{
  width:56px;height:56px;border-radius:50%;margin:0 auto;
  display:flex;align-items:center;justify-content:center;
  font-family:'Montserrat',sans-serif;font-size:18px;font-weight:800;
  border:3px solid var(--glass-border);position:relative;
}


/* ================================================================
   SLIDE 6: CHINA CASE STUDIES — Table + Metric Cards
   ================================================================ */
.china-highlights{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:24px}
.china-highlight-card{background:var(--glass);border-radius:var(--r-lg);padding:24px;backdrop-filter:blur(12px);position:relative;overflow:hidden}
.china-highlight-card::before{content:'';position:absolute;top:0;left:0;bottom:0;width:4px;border-radius:4px 0 0 4px}
.china-highlight-card.ping-an::before{background:var(--purple)}
.china-highlight-card.cmb::before{background:var(--cyan)}
.china-highlight-card .card-label{font-size:12px;font-weight:700;letter-spacing:1px;margin-bottom:12px}
.china-highlight-card .metrics-row{display:flex;gap:24px;justify-content:center}
.china-highlight-card .metric-item{text-align:center}
.china-highlight-card .metric-item .val{font-family:'Montserrat',sans-serif;font-size:32px;font-weight:800;line-height:1}
.china-highlight-card .metric-item .lbl{font-size:11px;color:var(--muted);margin-top:4px}


/* ================================================================
   SLIDE 7: LESSONS — Do/Don't + Hub Diagram (WeBank radial)
   ================================================================ */
.lessons-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.lessons-col{border-radius:var(--r-lg);padding:24px}
.lessons-col.dont{background:rgba(239,68,68,.04);border:1px solid rgba(239,68,68,.12)}
.lessons-col.do{background:rgba(16,185,129,.04);border:1px solid rgba(16,185,129,.12)}
.lessons-col h4{font-size:16px;margin-bottom:16px;display:flex;align-items:center;gap:8px}
.lesson-item{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px}
.lesson-item .icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}
.lesson-item .icon.x{background:rgba(239,68,68,.15);color:var(--danger)}
.lesson-item .icon.check{background:rgba(16,185,129,.15);color:var(--success)}
.lesson-item .text{font-size:13px;color:var(--muted);line-height:1.5}
.lesson-item .text strong{color:var(--text)}

/* Hub Diagram */
.hub-diagram{display:flex;justify-content:center;align-items:center;gap:0;margin-top:24px;position:relative}
.hub-center{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,rgba(249,102,24,.15),rgba(255,171,64,.1));border:2px solid rgba(249,102,24,.3);display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;z-index:2;position:relative}
.hub-center .hub-title{font-family:'Montserrat',sans-serif;font-size:10px;font-weight:700;color:var(--primary);letter-spacing:1px}
.hub-node{text-align:center;position:relative;z-index:2}
.hub-node .node-circle{width:68px;height:68px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-direction:column;margin:0 auto;border:2px solid var(--glass-border)}
.hub-node .node-circle .pct{font-family:'Montserrat',sans-serif;font-size:16px;font-weight:800}
.hub-node .node-circle .nlbl{font-size:9px;color:var(--muted)}
.hub-node .node-label{font-size:11px;color:var(--muted);margin-top:6px}
.hub-connector{width:60px;height:2px;background:linear-gradient(90deg,var(--glass-border),var(--primary),var(--glass-border));flex-shrink:0}

/* Hub Diagram — Large variant (WeBank radial) */
.hub-diagram-lg{position:relative;width:360px;height:360px;margin:var(--sp-xl) auto}
.hub-diagram-lg .hub-center{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:120px;height:120px;z-index:3;
}
.hub-diagram-lg .hub-node{position:absolute;z-index:2}
.hub-diagram-lg .hub-connector{
  position:absolute;top:50%;left:50%;transform-origin:0 0;
  height:2px;background:linear-gradient(90deg,rgba(249,102,24,.3),rgba(255,171,64,.1));
}


/* ================================================================
   SLIDE 8: VIETNAM OPPORTUNITY — Sidebar + Timeline
   ================================================================ */
.vietnam-layout{display:grid;grid-template-columns:35% 65%;gap:28px}
.vn-facts{display:flex;flex-direction:column;gap:14px}
.vn-fact-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--r-md);padding:16px;display:flex;align-items:center;gap:14px;backdrop-filter:blur(12px)}
.vn-fact-card .fact-icon{width:44px;height:44px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;flex-shrink:0}
.vn-fact-card .fact-text{font-size:13px;color:var(--muted);line-height:1.4}
.vn-fact-card .fact-text strong{color:var(--text)}
.vn-timeline{display:flex;flex-direction:column;gap:14px}
.vn-stage{border-radius:14px;padding:20px 24px;display:flex;justify-content:space-between;align-items:center;position:relative;overflow:hidden}
.vn-stage::before{content:'';position:absolute;top:0;left:0;bottom:0;width:5px;border-radius:4px 0 0 4px}
.vn-stage.first{background:rgba(16,185,129,.06);border:1px solid rgba(16,185,129,.15)}
.vn-stage.first::before{background:var(--success)}
.vn-stage.fast{background:rgba(255,171,64,.06);border:1px solid rgba(255,171,64,.15)}
.vn-stage.fast::before{background:var(--accent)}
.vn-stage.late{background:rgba(239,68,68,.06);border:1px solid rgba(239,68,68,.15)}
.vn-stage.late::before{background:var(--danger)}
.vn-stage .stage-info .stage-name{font-size:16px;font-weight:700}
.vn-stage .stage-info .stage-desc{font-size:12px;color:var(--muted);margin-top:2px}
.vn-stage .stage-period{font-family:'Montserrat',sans-serif;font-size:18px;font-weight:700;white-space:nowrap}


/* ================================================================
   SLIDE 9: MSB READINESS — Horizontal Score Bars
   ================================================================ */
.readiness-layout{display:grid;grid-template-columns:3fr 2fr;gap:32px}
.score-bar{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.score-bar .label{width:160px;font-size:13px;text-align:right;flex-shrink:0}
.score-bar .track{flex:1;height:24px;background:rgba(255,255,255,.04);border-radius:var(--r-sm);overflow:hidden}
.score-bar .fill{height:100%;border-radius:var(--r-sm);transition:width 1.2s var(--ease-out);display:flex;align-items:center;justify-content:flex-end;padding-right:10px;font-size:12px;font-weight:700;width:0}
.score-bar .value{width:55px;font-size:14px;font-weight:600;text-align:left}
.overall-score-circle{width:140px;height:140px;border-radius:50%;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;flex-direction:column;position:relative;border:3px solid rgba(255,171,64,.3)}
.overall-score-circle::before{content:'';position:absolute;inset:-6px;border-radius:50%;border:2px solid rgba(255,171,64,.1);animation:scorePulse 2s ease-in-out infinite}
@keyframes scorePulse{0%,100%{transform:scale(1);opacity:.4}50%{transform:scale(1.05);opacity:.8}}
.overall-score-circle .big-num{font-family:'Montserrat',sans-serif;font-size:48px;font-weight:900;color:var(--accent);line-height:1}
.overall-score-circle .of-total{font-size:14px;color:var(--muted)}


/* ================================================================
   SLIDE 10: STRATEGIC VISION — Pillars + Evolution Flow
   ================================================================ */
.vision-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px}
.vision-pillar{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:24px;text-align:center;position:relative;overflow:hidden}
.vision-pillar .pillar-num{width:36px;height:36px;border-radius:50%;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;font-family:'Montserrat',sans-serif;font-size:14px;font-weight:800;color:#fff}
.evolution-flow{display:flex;gap:0;align-items:stretch}
.evolution-stage{flex:1;position:relative;text-align:center}
.evolution-stage .evo-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:14px;padding:20px 14px;height:100%;position:relative}
.evolution-arrow{display:flex;align-items:center;justify-content:center;width:40px;flex-shrink:0;font-size:20px;color:var(--dim)}
.platform-bar{margin-top:16px;background:linear-gradient(90deg,rgba(139,92,246,.12),rgba(139,92,246,.06));border:1px solid rgba(139,92,246,.2);border-radius:var(--r-md);padding:12px 20px;text-align:center}


/* ================================================================
   SLIDE 11: ROADMAP — Horizontal Pipeline
   ================================================================ */
.pipeline{position:relative;display:flex;gap:0;margin-top:32px}
.pipeline::before{content:'';position:absolute;top:28px;left:5%;right:5%;height:4px;background:linear-gradient(90deg,var(--accent),var(--primary),var(--cyan),var(--success),var(--purple));border-radius:2px;z-index:0}
.pipeline-item{flex:1;text-align:center;position:relative;z-index:1}
.pipeline-dot{width:20px;height:20px;border-radius:50%;margin:19px auto 16px;border:3px solid var(--bg);position:relative;z-index:2;box-shadow:0 0 12px rgba(0,0,0,.5)}
.pipeline-phase{font-family:'Montserrat',sans-serif;font-size:14px;font-weight:700;margin-bottom:4px}
.pipeline-period{font-size:11px;color:var(--muted);margin-bottom:6px}
.pipeline-cost{font-family:'Montserrat',sans-serif;font-size:15px;font-weight:700;margin-bottom:6px}
.pipeline-desc{font-size:11px;color:var(--dim);line-height:1.4}
.pipeline-gate{display:flex;justify-content:space-around;margin-top:12px;gap:0}
.pipeline-gate-item{font-size:10px;color:var(--dim);text-align:center;flex:1}
.pipeline-gate-item .gate-icon{display:inline-block;width:16px;height:16px;border:2px solid var(--accent);border-radius:4px;transform:rotate(45deg);margin-bottom:4px}


/* ================================================================
   NEW: Flow Pipeline — Reusable (AgiBot timeline + WeBank pipeline)
   ================================================================ */
.flow-pipeline{
  position:relative;display:flex;align-items:flex-start;gap:0;
  padding:var(--sp-xl) 0;
}
.flow-pipeline::before{
  content:'';position:absolute;top:36px;left:8%;right:8%;height:3px;
  background:linear-gradient(90deg,var(--primary),var(--accent),var(--cyan),var(--success));
  border-radius:2px;z-index:0;
}
.flow-node{
  flex:1;display:flex;flex-direction:column;align-items:center;
  position:relative;z-index:1;
}
.flow-node .flow-dot{
  width:18px;height:18px;border-radius:50%;
  border:3px solid var(--bg);margin-bottom:var(--sp-md);
  box-shadow:0 0 10px rgba(0,0,0,.4);position:relative;z-index:2;
}
.flow-node .flow-dot::after{
  content:'';position:absolute;inset:-4px;border-radius:50%;
  border:2px solid currentColor;opacity:.2;
}
.flow-content{text-align:center;padding:0 var(--sp-sm)}
.flow-content .flow-title{font-family:'Montserrat',sans-serif;font-size:13px;font-weight:700;margin-bottom:4px}
.flow-content .flow-desc{font-size:11px;color:var(--muted);line-height:1.4}
.flow-line{
  width:60px;height:3px;flex-shrink:0;
  background:linear-gradient(90deg,var(--glass-border),var(--primary),var(--glass-border));
  border-radius:2px;margin-top:36px;
}


/* ================================================================
   SLIDE 12: DEPLOYMENT MODELS — Grid with Highlight Column
   ================================================================ */
.deploy-table-wrap{position:relative}
.deploy-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;border-radius:var(--r-md);overflow:hidden}
.deploy-table thead th{background:rgba(249,102,24,.12);color:var(--primary);font-weight:600;padding:12px 14px;text-align:center;font-size:12px;letter-spacing:.5px;border-bottom:2px solid rgba(249,102,24,.25)}
.deploy-table thead th:first-child{text-align:left}
.deploy-table thead th.dt-highlight{background:rgba(255,171,64,.2);color:var(--accent);box-shadow:inset 0 -2px 0 var(--accent)}
.deploy-table tbody td{padding:10px 14px;border-bottom:1px solid var(--glass-border);text-align:center}
.deploy-table tbody td:first-child{text-align:left;font-weight:600}
.deploy-table tbody td.dt-highlight{background:rgba(255,171,64,.06);border-left:1px solid rgba(255,171,64,.1);border-right:1px solid rgba(255,171,64,.1)}
.why-dual-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:20px}
.why-dual-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--r-md);padding:14px;text-align:center;backdrop-filter:blur(12px)}
.why-dual-card .num{font-family:'Montserrat',sans-serif;font-size:18px;font-weight:800;color:var(--accent);margin-bottom:6px}
.why-dual-card .txt{font-size:11px;color:var(--muted);line-height:1.4}


/* ================================================================
   NEW: Comparison Highlight Column — Reusable
   ================================================================ */
.compare-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;border-radius:var(--r-md);overflow:hidden}
.compare-table thead th{background:rgba(255,255,255,.04);color:var(--muted);font-weight:600;padding:12px 14px;text-align:center;font-size:12px;border-bottom:2px solid var(--glass-border)}
.compare-table thead th:first-child{text-align:left}
.compare-table .highlight-col-header{background:rgba(255,171,64,.2)!important;color:var(--accent)!important;box-shadow:inset 0 -2px 0 var(--accent)}
.compare-table tbody td{padding:10px 14px;border-bottom:1px solid var(--glass-border);text-align:center}
.compare-table tbody td:first-child{text-align:left;font-weight:600;color:var(--text)}
.compare-table .highlight-col{background:rgba(255,171,64,.05);border-left:1px solid rgba(255,171,64,.1);border-right:1px solid rgba(255,171,64,.1);color:var(--accent);font-weight:700}


/* ================================================================
   SLIDE 13: FINANCIAL — KPI Grid + Scenario Cards
   ================================================================ */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:28px}
.kpi-item{text-align:center;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:20px 12px;backdrop-filter:blur(12px)}
.kpi-item .kpi-val{font-family:'Montserrat',sans-serif;font-size:clamp(24px,2.5vw,32px);font-weight:800;line-height:1;margin-bottom:4px}
.kpi-item .kpi-label{font-size:12px;color:var(--muted)}
.scenario-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.scenario-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:24px;text-align:center;backdrop-filter:blur(12px)}
.scenario-card.base{border:2px solid rgba(255,171,64,.3);box-shadow:0 0 20px rgba(255,171,64,.08)}
.scenario-card .sc-label{font-size:11px;font-weight:700;letter-spacing:2px;margin-bottom:4px}
.scenario-card .sc-sub{font-size:13px;color:var(--muted);margin-bottom:12px}
.scenario-card .sc-num{font-family:'Montserrat',sans-serif;font-size:36px;font-weight:800;line-height:1;margin-bottom:4px}
.scenario-card .sc-unit{font-size:12px;color:var(--muted);margin-bottom:12px}
.scenario-card .sc-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.scenario-card .sc-metric{text-align:center}
.scenario-card .sc-metric .v{font-size:18px;font-weight:800}
.scenario-card .sc-metric .l{font-size:10px;color:var(--muted);margin-top:2px}


/* ================================================================
   NEW: KPI Grid — 2x2 Quadrant (WeBank style)
   ================================================================ */
.kpi-grid-2x2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.kpi-card{
  background:var(--glass);border:1px solid var(--glass-border);
  border-radius:var(--r-lg);padding:var(--sp-xl);
  backdrop-filter:blur(12px);position:relative;overflow:hidden;
  display:flex;align-items:center;gap:var(--sp-lg);
}
.kpi-card .kpi-icon{
  width:56px;height:56px;border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  font-size:24px;flex-shrink:0;
}
.kpi-card .kpi-data{flex:1}
.kpi-card .kpi-data .kpi-number{font-family:'Montserrat',sans-serif;font-size:clamp(28px,3vw,40px);font-weight:900;line-height:1;margin-bottom:4px}
.kpi-card .kpi-data .kpi-desc{font-size:13px;color:var(--muted);line-height:1.4}


/* ================================================================
   SLIDE 14: RISK — Cards with Severity Meters
   ================================================================ */
.risk-cards{display:flex;flex-direction:column;gap:14px}
.risk-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:14px;padding:18px 24px;display:grid;grid-template-columns:auto 1fr auto auto;gap:16px;align-items:center;backdrop-filter:blur(12px);transition:transform .2s}
.risk-card:hover{transform:translateX(4px)}
.risk-card .rid{font-family:'Montserrat',sans-serif;font-size:16px;font-weight:800;width:36px}
.risk-card .rinfo{min-width:0}
.risk-card .rinfo .rname{font-size:14px;font-weight:700}
.risk-card .rinfo .rsolution{font-size:12px;color:var(--muted);margin-top:2px}
.risk-card .rinfo .rsolution strong{color:var(--text)}
.risk-meter{display:flex;gap:3px;align-items:center}
.risk-block{width:12px;height:20px;border-radius:3px;background:rgba(255,255,255,.06)}
.risk-block.filled-red{background:var(--danger)}.risk-block.filled-amber{background:var(--accent)}.risk-block.filled-green{background:var(--success)}
.risk-card .rscore{font-size:11px;font-weight:600;white-space:nowrap}
.fallback-flow{display:flex;align-items:center;gap:0;flex-wrap:wrap;justify-content:center;margin-top:20px}
.fallback-node{padding:8px 14px;border-radius:8px;font-size:12px;font-weight:600;text-align:center}
.fallback-arrow{font-size:16px;color:var(--dim);padding:0 4px}


/* ================================================================
   NEW: Severity Meter — Reusable (WeBank violation style)
   ================================================================ */
.severity-meter{display:flex;gap:4px;align-items:center}
.severity-block{
  width:14px;height:22px;border-radius:3px;
  background:rgba(255,255,255,.06);transition:background var(--duration) var(--ease-out);
}
.severity-block.high{background:var(--danger)}
.severity-block.medium{background:var(--accent)}
.severity-block.low{background:var(--success)}
.severity-block.filled{background:currentColor}

/* Severity meter with labels */
.severity-meter-labeled{display:flex;align-items:center;gap:var(--sp-sm)}
.severity-meter-labeled .severity-label{font-size:11px;font-weight:600;white-space:nowrap}


/* ================================================================
   SLIDE 15: PHASE 0 — Gantt Timeline + Decision Box
   ================================================================ */
.phase0-top{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px}
.phase0-metric{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:24px;text-align:center;backdrop-filter:blur(12px)}
.phase0-metric .p0-val{font-family:'Montserrat',sans-serif;font-size:clamp(28px,3vw,40px);font-weight:900;line-height:1;margin-bottom:4px}
.phase0-metric .p0-label{font-size:12px;color:var(--muted)}

/* Gantt Chart */
.gantt{display:flex;flex-direction:column;gap:6px;margin-bottom:24px;position:relative}
.gantt-header{display:grid;grid-template-columns:180px repeat(12,1fr);gap:0;padding:0 0 8px;border-bottom:1px solid var(--glass-border)}
.gantt-header span{font-size:10px;color:var(--dim);text-align:center}
.gantt-header span:first-child{text-align:left;font-weight:600;color:var(--muted)}
.gantt-row{display:grid;grid-template-columns:180px repeat(12,1fr);gap:0;align-items:center;height:28px}
.gantt-row .gantt-label{font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gantt-bar{height:18px;border-radius:4px;position:relative}

/* Gantt — Extended support for more columns */
.gantt-24 .gantt-header,.gantt-24 .gantt-row{grid-template-columns:180px repeat(24,1fr)}
.gantt-48 .gantt-header,.gantt-48 .gantt-row{grid-template-columns:180px repeat(48,1fr)}

/* Gantt bar interaction */
.gantt-bar:hover{filter:brightness(1.2);box-shadow:0 0 10px rgba(255,255,255,.1)}
.gantt-bar .gantt-bar-label{
  position:absolute;left:8px;top:50%;transform:translateY(-50%);
  font-size:10px;font-weight:600;color:#fff;white-space:nowrap;
}


/* ================================================================
   SLIDE 16: CLOSING CTA — Pills + Quote + Decision
   ================================================================ */
.reason-pills{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:28px}
.reason-pill{display:flex;align-items:center;gap:8px;background:var(--glass);border:1px solid var(--glass-border);border-radius:30px;padding:10px 18px;backdrop-filter:blur(12px);transition:transform .2s}
.reason-pill:hover{transform:scale(1.03)}
.reason-pill .pill-check{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}
.reason-pill .pill-text{font-size:13px;font-weight:600}

/* Decision Box */
.decision-box{background:linear-gradient(135deg,rgba(249,102,24,.12),rgba(255,171,64,.12));border:2px solid var(--accent);border-radius:var(--r-lg);padding:32px;text-align:center}

/* Quote Box */
.quote-box{border-left:4px solid var(--accent);padding:16px 24px;font-style:italic;color:var(--muted);font-size:16px;background:rgba(255,171,64,.04);border-radius:0 var(--r-sm) var(--r-sm) 0}

/* CTA Quote */
.cta-quote{background:linear-gradient(135deg,rgba(249,102,24,.1),rgba(255,171,64,.08),rgba(0,174,199,.06));border:1px solid rgba(255,171,64,.15);border-radius:var(--r-xl);padding:32px 40px;text-align:center;font-size:clamp(16px,1.8vw,20px);font-style:italic;color:var(--muted);line-height:1.7;position:relative;margin-top:20px}
.cta-quote::before{content:'\201C';font-size:64px;color:var(--accent);opacity:.3;position:absolute;top:8px;left:20px;font-family:Georgia,serif;line-height:1}

/* Approve Badge with Pulse */
.approve-badge{display:inline-block;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;font-family:'Montserrat',sans-serif;font-weight:800;font-size:14px;letter-spacing:3px;padding:10px 32px;border-radius:8px;margin-top:20px;animation:approvePulse 2s ease-in-out infinite}
@keyframes approvePulse{0%,100%{box-shadow:0 0 20px rgba(249,102,24,.3)}50%{box-shadow:0 0 40px rgba(249,102,24,.6)}}


/* ================================================================
   NEW: Vertical Accent Bar (AgiBot signature)
   ================================================================ */
.accent-bar{
  position:relative;padding-left:20px;
}
.accent-bar::before{
  content:'';position:absolute;top:0;left:0;bottom:0;width:4px;
  background:linear-gradient(180deg,var(--primary),var(--accent));
  border-radius:2px;
}
.accent-bar-section{
  position:relative;padding-left:24px;margin-bottom:var(--sp-lg);
}
.accent-bar-section::before{
  content:'';position:absolute;top:0;left:0;height:100%;width:4px;
  background:linear-gradient(180deg,var(--primary),var(--accent));
  border-radius:2px;
}
.accent-bar-section .section-title{
  font-family:'Montserrat',sans-serif;font-size:18px;font-weight:700;margin-bottom:8px;
}
.accent-bar-section .section-desc{font-size:13px;color:var(--muted);line-height:1.6}

/* Color variants */
.accent-bar-success::before{background:linear-gradient(180deg,var(--success),#34d399)}
.accent-bar-danger::before{background:linear-gradient(180deg,var(--danger),#f87171)}
.accent-bar-cyan::before{background:linear-gradient(180deg,var(--cyan),#22d3ee)}
.accent-bar-purple::before{background:linear-gradient(180deg,var(--purple),#a78bfa)}


/* ================================================================
   NEW: Pill Badges (AgiBot style)
   ================================================================ */
.pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 14px;border-radius:var(--r-full);
  font-size:12px;font-weight:600;
  background:var(--glass);border:1px solid var(--glass-border);
  backdrop-filter:blur(8px);white-space:nowrap;
}
.pill-primary{background:rgba(249,102,24,.12);border-color:rgba(249,102,24,.25);color:var(--primary)}
.pill-success{background:rgba(16,185,129,.12);border-color:rgba(16,185,129,.25);color:var(--success)}
.pill-danger{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.25);color:var(--danger)}
.pill-cyan{background:rgba(0,174,199,.12);border-color:rgba(0,174,199,.25);color:var(--cyan)}
.pill-purple{background:rgba(139,92,246,.12);border-color:rgba(139,92,246,.25);color:var(--purple)}
.pill-accent{background:rgba(255,171,64,.12);border-color:rgba(255,171,64,.25);color:var(--accent)}

/* Pill with icon dot */
.pill .pill-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.pill-primary .pill-dot{background:var(--primary)}
.pill-success .pill-dot{background:var(--success)}
.pill-danger .pill-dot{background:var(--danger)}
.pill-cyan .pill-dot{background:var(--cyan)}
.pill-purple .pill-dot{background:var(--purple)}
.pill-accent .pill-dot{background:var(--accent)}


/* ================================================================
   NEW: Sidebar + Content Layout
   ================================================================ */
.layout-sidebar{display:grid;grid-template-columns:35% 65%;gap:32px;align-items:start}
.layout-sidebar-reverse{display:grid;grid-template-columns:65% 35%;gap:32px;align-items:start}
.layout-sidebar-equal{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}

/* 3-column layout */
.layout-3col{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.layout-4col{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}


/* ================================================================
   NEW: Quote Box with Gradient (WeBank style)
   ================================================================ */
.quote-gradient{
  background:linear-gradient(135deg,rgba(249,102,24,.08),rgba(255,171,64,.06),rgba(0,174,199,.04));
  border:1px solid rgba(255,171,64,.12);
  border-radius:var(--r-xl);
  padding:var(--sp-xl) var(--sp-2xl);
  text-align:center;position:relative;
  font-size:clamp(16px,2vw,22px);font-style:italic;
  color:var(--muted);line-height:1.7;
}
.quote-gradient::before{
  content:'\201C';font-size:72px;color:var(--accent);opacity:.25;
  position:absolute;top:4px;left:24px;font-family:Georgia,serif;line-height:1;
}
.quote-gradient::after{
  content:'\201D';font-size:72px;color:var(--accent);opacity:.25;
  position:absolute;bottom:4px;right:24px;font-family:Georgia,serif;line-height:1;
}
.quote-gradient .quote-author{
  font-size:13px;font-style:normal;font-weight:600;
  color:var(--dim);margin-top:var(--sp-md);letter-spacing:1px;
}


/* ================================================================
   NEW: Decision Box — Prominent CTA (enhanced)
   ================================================================ */
.decision-box-lg{
  background:linear-gradient(135deg,rgba(249,102,24,.1),rgba(255,171,64,.08));
  border:2px solid var(--accent);border-radius:var(--r-xl);
  padding:var(--sp-2xl);text-align:center;
  position:relative;overflow:hidden;
}
.decision-box-lg::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at center,rgba(255,171,64,.06) 0%,transparent 70%);
  pointer-events:none;
}
.approve-badge-lg{
  display:inline-block;
  background:linear-gradient(135deg,var(--primary),var(--accent));
  color:#fff;font-family:'Montserrat',sans-serif;
  font-weight:800;font-size:16px;letter-spacing:4px;
  padding:14px 44px;border-radius:var(--r-md);
  margin-top:var(--sp-lg);
  animation:approvePulse 2s ease-in-out infinite;
  cursor:pointer;transition:transform .2s;
}
.approve-badge-lg:hover{transform:scale(1.05)}


/* ================================================================
   NEW: Gantt Timeline — Enhanced
   ================================================================ */
.gantt-milestone{
  position:absolute;top:50%;transform:translate(-50%,-50%) rotate(45deg);
  width:12px;height:12px;border:2px solid var(--accent);
  background:var(--bg);z-index:2;
}
.gantt-today{
  position:absolute;top:0;bottom:0;width:2px;
  background:var(--danger);z-index:3;opacity:.6;
}
.gantt-today::after{
  content:'Today';position:absolute;top:-18px;left:50%;transform:translateX(-50%);
  font-size:9px;color:var(--danger);font-weight:600;white-space:nowrap;
}


/* ================================================================
   UTILITY CLASSES
   ================================================================ */

/* Flexbox helpers */
.flex{display:flex}.flex-col{flex-direction:column}
.flex-wrap{flex-wrap:wrap}
.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}
.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}
.gap-xs{gap:var(--sp-xs)}.gap-sm{gap:var(--sp-sm)}.gap-md{gap:var(--sp-md)}.gap-lg{gap:var(--sp-lg)}.gap-xl{gap:var(--sp-xl)}

/* Spacing */
.mt-sm{margin-top:var(--sp-sm)}.mt-md{margin-top:var(--sp-md)}.mt-lg{margin-top:var(--sp-lg)}.mt-xl{margin-top:var(--sp-xl)}.mt-2xl{margin-top:var(--sp-2xl)}
.mb-sm{margin-bottom:var(--sp-sm)}.mb-md{margin-bottom:var(--sp-md)}.mb-lg{margin-bottom:var(--sp-lg)}.mb-xl{margin-bottom:var(--sp-xl)}.mb-2xl{margin-bottom:var(--sp-2xl)}

/* Text alignment */
.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}

/* Color utilities */
.color-primary{color:var(--primary)}.color-accent{color:var(--accent)}
.color-success{color:var(--success)}.color-danger{color:var(--danger)}
.color-purple{color:var(--purple)}.color-cyan{color:var(--cyan)}
.color-muted{color:var(--muted)}.color-dim{color:var(--dim)}

/* Border utilities */
.border-top-primary{border-top:3px solid var(--primary)}
.border-top-accent{border-top:3px solid var(--accent)}
.border-top-success{border-top:3px solid var(--success)}
.border-top-danger{border-top:3px solid var(--danger)}
.border-top-cyan{border-top:3px solid var(--cyan)}
.border-top-purple{border-top:3px solid var(--purple)}
.border-left-primary{border-left:4px solid var(--primary)}
.border-left-accent{border-left:4px solid var(--accent)}
.border-left-success{border-left:4px solid var(--success)}
.border-left-danger{border-left:4px solid var(--danger)}
.border-left-cyan{border-left:4px solid var(--cyan)}
.border-left-purple{border-left:4px solid var(--purple)}

/* Overflow control */
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}


/* ================================================================
   RESPONSIVE — 1200px
   ================================================================ */
@media(max-width:1200px){
  .exec-cards{grid-template-columns:repeat(3,1fr)}
  .vendor-grid{grid-template-columns:repeat(3,1fr)}
  .metric-circles{grid-template-columns:repeat(2,1fr)}
  .why-dual-cards{grid-template-columns:repeat(3,1fr)}
  .product-grid{grid-template-columns:repeat(3,1fr)}
  .layout-3col{grid-template-columns:repeat(2,1fr)}
  .layout-4col{grid-template-columns:repeat(2,1fr)}
  .kpi-grid-2x2{grid-template-columns:1fr 1fr}
}


/* ================================================================
   RESPONSIVE — 1024px (tablet landscape)
   ================================================================ */
@media(max-width:1024px){
  .slide{padding:40px 32px}
  .exec-cards{grid-template-columns:repeat(2,1fr)}
  .vendor-grid{grid-template-columns:repeat(2,1fr)}
  .inflection-split,.split-layout{grid-template-columns:1fr;gap:16px}
  .inflection-divider,.split-divider{width:auto;height:40px;flex-direction:row}
  .inflection-divider::before,.split-divider::before{top:50%;left:0;right:0;width:auto;height:2px;transform:none}
  .inflection-col.before-col,.inflection-col.after-col,.split-left,.split-right{border-radius:var(--r-lg);border:1px solid var(--glass-border)}
  .vietnam-layout,.layout-sidebar,.layout-sidebar-reverse{grid-template-columns:1fr}
  .readiness-layout{grid-template-columns:1fr}
  .pipeline,.flow-pipeline{flex-wrap:wrap;gap:12px}
  .pipeline::before,.flow-pipeline::before{display:none}
  .pipeline-item,.flow-node{flex:0 0 calc(33% - 8px)}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .flow-line{display:none}
  .layout-3col{grid-template-columns:1fr 1fr}
  .layout-4col{grid-template-columns:1fr 1fr}
}


/* ================================================================
   RESPONSIVE — 768px (tablet portrait / mobile)
   ================================================================ */
@media(max-width:768px){
  .slide{padding:24px 16px}
  .exec-cards,.vendor-grid,.vision-pillars,.scenario-cards,.product-grid{grid-template-columns:1fr}
  .metric-circles{grid-template-columns:1fr 1fr}
  .why-dual-cards{grid-template-columns:1fr 1fr}
  .lessons-grid{grid-template-columns:1fr}
  .hub-diagram{flex-direction:column}
  .hub-connector{width:2px;height:30px;background:linear-gradient(180deg,var(--glass-border),var(--primary),var(--glass-border))}
  .evolution-flow{flex-direction:column}
  .evolution-arrow{width:auto;height:30px;transform:rotate(90deg)}
  .pipeline-item,.flow-node{flex:0 0 calc(50% - 6px)}
  .inflection-metrics{grid-template-columns:repeat(2,1fr)}
  .data-table,.deploy-table,.compare-table{font-size:11px}
  .data-table thead th,.data-table tbody td,.deploy-table thead th,.deploy-table tbody td,.compare-table thead th,.compare-table tbody td{padding:8px 8px}
  .score-bar .label{width:110px;font-size:11px}
  .risk-card{grid-template-columns:auto 1fr;gap:10px}
  .risk-card .risk-meter-col,.risk-card .rscore{display:none}
  .phase0-top{grid-template-columns:1fr}
  .gantt{display:none}
  .fallback-flow{gap:4px}
  #slide-cover .cover-content{padding:40px 24px;max-width:100%}
  #slide-cover .cover-curved{width:100%;height:60%}
  #slide-cover .cover-bg{width:100%;height:50%;top:auto;bottom:0}
  .kpi-grid-2x2{grid-template-columns:1fr}
  .layout-sidebar,.layout-sidebar-reverse,.layout-sidebar-equal{grid-template-columns:1fr}
  .layout-3col,.layout-4col{grid-template-columns:1fr}
  .reason-pills{flex-direction:column;align-items:stretch}
  .reason-pill{justify-content:center}
  .quote-gradient{padding:var(--sp-lg) var(--sp-lg)}
  .quote-gradient::before,.quote-gradient::after{font-size:48px}
}


/* ================================================================
   PRINT STYLES
   ================================================================ */
@media print{
  html{scroll-snap-type:none}
  .slide{min-height:auto;height:100vh;page-break-after:always;page-break-inside:avoid;padding:40px}
  #progress-bar,#slide-counter,#nav-hint{display:none}
  .reveal,.reveal-left,.reveal-right,.reveal-scale{opacity:1!important;transform:none!important}
  .stagger-children > *{opacity:1!important;transform:none!important}
  body{background:#fff;color:#1a1a2e}
  .card,.card-elevated,.exec-card,.vendor-card,.scenario-card,.kpi-item,.kpi-card,.risk-card,.phase0-metric,.vn-fact-card,.product-card{background:#f8f9fa;border-color:#e2e8f0}
  .data-table thead th,.deploy-table thead th,.compare-table thead th{background:#e2e8f0;color:#1a1a2e}
  .cover-title,.slide-title{-webkit-text-fill-color:#1a1a2e}
  #slide-cover .cover-curved::before{background:#f8f9fa!important}
  #cover-canvas{display:none}
  .approve-badge,.approve-badge-lg{animation:none;box-shadow:none;border:2px solid #F96618}
  .glow-border,.glow-primary,.glow-success{box-shadow:none}
  .pill,.pill-primary,.pill-success,.pill-danger,.pill-cyan,.pill-purple,.pill-accent{border:1px solid #cbd5e1}
}
