/* =============================================
   MK1 Technology — LP制作 Landing Page
   Full rebuild — 13 sections from Content.md
   Style guide: style.md
   ============================================= */

:root {
  --blue: #0A84FF;
  --blue-dark: #0040DD;
  --blue-deep: #05142b;
  --violet: #BF5AF2;
  --accent: #5E5CE6;
  --text: #1D1D1F;
  --text2: #86868B;
  --bg: #ffffff;
  --bg2: #f5f5f7;
  --glass: rgba(255, 255, 255, 0.7);
  --glass-border: rgba(255, 255, 255, 0.4);
  --shadow: 0 8px 32px 0 rgba(31, 38, 135, 0.07);
  --shadow2: 0 12px 48px 0 rgba(31, 38, 135, 0.15);
  --r-card: 24px;
  --r-pill: 9999px;
}

/* ===== Base ===== */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Noto Sans JP','Montserrat',sans-serif;color:var(--text);background:var(--bg);line-height:1.75;letter-spacing:0.02em;overflow-x:hidden}
a{color:inherit}
img{max-width:100%;display:block}
ul{list-style:none}

/* Noise overlay */
body::before{content:'';position:fixed;inset:0;background:url('https://grainy-gradients.vercel.app/noise.svg');opacity:.03;z-index:9999;pointer-events:none;mix-blend-mode:overlay}

/* Scroll progress */
.scroll-progress{position:fixed;top:0;left:0;width:0%;height:3px;background:linear-gradient(90deg,var(--blue),var(--violet));z-index:1001;transition:width .1s ease}

/* Background patterns */
.bg-lines{background-image:linear-gradient(var(--bg2) 1px,transparent 1px),linear-gradient(90deg,var(--bg2) 1px,transparent 1px);background-size:60px 60px}
.bg-dots{background-image:radial-gradient(rgba(10,132,255,0.08) 2px,transparent 2px);background-size:32px 32px}

/* Decorative orbs */
.bg-orb-decor{position:absolute;border-radius:50%;filter:blur(100px);pointer-events:none;z-index:0}

/* Watermark */
.bg-watermark{position:absolute;font-size:20vw;font-weight:900;color:rgba(0,0,0,0.03);z-index:0;pointer-events:none;white-space:nowrap;line-height:1;font-family:'Noto Sans JP';bottom:10%;right:-5%;opacity:1}

/* Mono utility */
.mono,.mono-num{font-family:'Montserrat',sans-serif}
.mono{font-weight:600;font-size:12px;letter-spacing:0.08em;text-transform:uppercase}
.mono-num{font-weight:800;font-size:14px}

/* ===== Typography ===== */
.section{padding:100px 0;scroll-margin-top:80px;position:relative}
.section--alt{background:var(--bg2)}
.container{max-width:1200px;margin:0 auto;padding:0 32px;position:relative;z-index:1}

.section-badge{display:inline-flex;align-items:center;gap:12px;margin-bottom:24px;position:relative}
.section-badge-dot{width:10px;height:10px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--violet));flex-shrink:0;position:relative;animation:badge-pulse 2.5s ease-in-out infinite}
.section-badge-dot::after{content:'';position:absolute;inset:-4px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--violet));opacity:0.3;filter:blur(4px)}
@keyframes badge-pulse{0%,100%{opacity:0.7;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}
.section-badge-text{font-family:'Montserrat',sans-serif;font-size:13px;font-weight:800;letter-spacing:0.35em;text-transform:uppercase;background:linear-gradient(135deg,var(--blue),var(--violet));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.section-badge-line{position:absolute;left:100%;top:50%;transform:translateY(-50%);margin-left:12px;width:40px;height:2px;background:linear-gradient(90deg,var(--blue),transparent);border-radius:2px}

.section-title{font-size:48px;font-weight:800;letter-spacing:-0.03em;line-height:1.2;margin-bottom:24px;background:linear-gradient(135deg,#1d1d1f 0%,#434343 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.section-title em{font-style:normal}
.section-title--light{background:linear-gradient(135deg,#ffffff 0%,rgba(255,255,255,0.7) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.section-title--light em{-webkit-text-fill-color:var(--blue)}
.section-sub{font-size:18px;color:var(--text2);max-width:700px;margin:0 auto}
.section-sub--light{color:rgba(255,255,255,0.55);max-width:800px}
.section-head{margin-bottom:56px;display:flex;flex-direction:column;align-items:center;text-align:center}

/* ===== Header ===== */
.site-header{position:fixed;top:0;left:0;width:100%;height:80px;background:rgba(255,255,255,0.95);backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);z-index:1000;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:0 48px;transition:all .3s ease}
.site-header.scrolled{height:72px;box-shadow:0 10px 30px rgba(0,0,0,0.05)}
#main-nav{display:flex;justify-content:center;gap:24px;align-items:center}
.logo{display:flex;justify-content:flex-start}
.nav-cta-wrap{display:flex;justify-content:flex-end;align-items:center;gap:8px}

.logo-link{text-decoration:none;display:flex;align-items:center}
.logo-img{height:52px;width:auto;object-fit:contain;transition:height .3s ease}

.nav-link{font-size:14px;font-weight:700;color:var(--text);text-decoration:none;transition:color .2s;font-family:'Noto Sans JP',sans-serif;white-space:nowrap}
.nav-link:hover,.nav-link.active,.nav-link.is-active{color:var(--blue)}
.nav-cta{background:var(--blue);color:#fff !important;height:44px;padding:0 24px;border-radius:var(--r-pill);font-size:14px;font-weight:700;text-decoration:none !important;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 4px 15px rgba(10,132,255,0.25);transition:all .3s ease;white-space:nowrap}
.nav-cta:hover{background:var(--blue-dark) !important;transform:translateY(-2px);box-shadow:0 6px 20px rgba(10,132,255,0.35)}
.nav-cta-desktop{display:inline-flex}
.nav-cta-mobile{display:none}

/* ===== Buttons ===== */
.btn-primary{display:inline-flex;align-items:center;gap:12px;padding:18px 36px;border-radius:var(--r-pill);font-weight:800;font-size:16px;transition:all .3s ease;position:relative;overflow:hidden;cursor:pointer;border:none;font-family:inherit;text-decoration:none}
.btn-grad{background:linear-gradient(135deg,var(--blue),var(--accent));color:#fff;box-shadow:0 10px 30px rgba(10,132,255,0.3)}
.btn-primary::after{content:'';position:absolute;top:-50%;left:-100%;width:40%;height:200%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.25),transparent);transform:skewX(-15deg);pointer-events:none;opacity:0}
.btn-primary:hover::after{animation:shimmer-sweep 1s ease forwards}
.btn-grad:hover{box-shadow:0 15px 40px rgba(10,132,255,0.4);transform:translateY(-2px)}
@keyframes shimmer-sweep{0%{left:-100%;opacity:1}100%{left:150%;opacity:1}}
.btn-arrow{font-family:'Montserrat',sans-serif;font-weight:700;transition:transform .3s}
.btn-primary:hover .btn-arrow{transform:translateX(4px)}

/* Pulse ring on CTA */
.btn-pulse-ring{position:absolute;inset:0;border-radius:inherit;box-shadow:0 0 0 0 rgba(10,132,255,0.4);animation:btn-ring-pulse 2.5s ease-in-out infinite;pointer-events:none}
@keyframes btn-ring-pulse{0%{box-shadow:0 0 0 0 rgba(10,132,255,0.4)}70%{box-shadow:0 0 0 12px rgba(10,132,255,0)}100%{box-shadow:0 0 0 0 rgba(10,132,255,0)}}

.btn-secondary{padding:18px 36px;border-radius:var(--r-pill);border:1px solid rgba(0,0,0,0.12);color:var(--text);font-weight:700;font-size:16px;transition:all .3s;background:#fff;text-decoration:none;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;gap:12px}
.btn-secondary:hover{background:rgba(10,132,255,0.04);border-color:var(--blue);color:var(--blue)}

/* ===== Glass Cards ===== */
.glass-card{background:rgba(255,255,255,0.7);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.4);border-radius:var(--r-card);box-shadow:var(--shadow);transition:all .3s ease}
.glass-card:hover{transform:translateY(-6px);box-shadow:var(--shadow2);border-color:var(--blue)}

/* ===== 01 HERO ===== */
.hero{min-height:800px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:120px 0 40px;color:var(--text);background:linear-gradient(170deg,#f8fbff 0%,#ffffff 30%,#f5f3ff 60%,#f0f7ff 100%)}
.hero .container{width:100%;position:relative;z-index:3}

/* Animated gradient mesh */
.hero-mesh{position:absolute;inset:0;z-index:0;background:
  radial-gradient(ellipse 600px 500px at 20% 30%, rgba(10,132,255,0.08) 0%, transparent 70%),
  radial-gradient(ellipse 500px 400px at 80% 60%, rgba(191,90,242,0.06) 0%, transparent 70%),
  radial-gradient(ellipse 400px 300px at 50% 80%, rgba(94,92,230,0.05) 0%, transparent 70%);
animation:mesh-shift 12s ease-in-out infinite alternate}
@keyframes mesh-shift{0%{filter:blur(0);opacity:1}50%{filter:blur(20px);opacity:0.8}100%{filter:blur(0);opacity:1}}

.hero-orb{position:absolute;border-radius:50%;filter:blur(100px);pointer-events:none;z-index:2}
.hero-orb-1{width:600px;height:600px;background:rgba(10,132,255,0.1);top:-100px;right:-100px}
.hero-orb-2{width:500px;height:500px;background:rgba(191,90,242,0.07);bottom:-100px;left:-100px}

/* Floating geometric shapes */
.hero-shapes{position:absolute;inset:0;pointer-events:none;z-index:1}
.geo{position:absolute;border:1.5px solid rgba(10,132,255,0.12);opacity:0.5}
.geo-1{width:60px;height:60px;top:12%;left:8%;clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);animation:geo-spin 30s linear infinite,sticker-float 7s ease-in-out infinite}
.geo-2{width:40px;height:40px;top:70%;left:15%;border-radius:50%;border-color:rgba(191,90,242,0.15);animation:geo-spin 25s linear infinite reverse,sticker-float 9s ease-in-out infinite 1s}
.geo-3{width:36px;height:36px;top:25%;right:30%;transform:rotate(45deg);animation:geo-spin 20s linear infinite,sticker-float 8s ease-in-out infinite 2s}
.geo-4{width:20px;height:20px;bottom:30%;right:12%;border-radius:4px;border-color:rgba(94,92,230,0.12);animation:geo-spin 35s linear infinite reverse,sticker-float 6s ease-in-out infinite 3s}
@keyframes geo-spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

.hero-grid{display:grid;grid-template-columns:minmax(0, 1.3fr) 360px;gap:20px;align-items:start}
.hero-eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.eb-line{width:32px;height:2px;background:linear-gradient(90deg,var(--blue),transparent);border-radius:2px}
.hero-eyebrow .mono{color:var(--text2);font-size:13px}

.hero-headline{margin-bottom:24px}
.line-wrap{overflow:hidden}
.hero-line-anim{display:block;transform:translateY(110%);opacity:0;animation:slide-up 0.8s cubic-bezier(0.16,1,0.3,1) forwards;animation-delay:var(--d)}
@keyframes slide-up{to{transform:translateY(0);opacity:1}}

.hero-line{font-size:clamp(28px,4.5vw,48px);font-weight:800;line-height:1.2;letter-spacing:-0.02em;color:var(--text);white-space:nowrap;display:inline-block}
.hero-num{font-family:'Montserrat',sans-serif;font-size:clamp(48px,8vw,80px);font-weight:900;background:linear-gradient(135deg,#0A84FF,#BF5AF2);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 20px rgba(10,132,255,0.3));line-height:1.1;font-style:normal;vertical-align:middle}
.hero-hl{background:linear-gradient(135deg,var(--blue),var(--violet));color:#fff;font-style:normal;position:relative;padding:0 24px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;height:clamp(52.8px,8.8vw,88px);overflow:hidden;margin-left:-0.3em;vertical-align:middle}
.hero-hl::after{content:'';position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.4),transparent);animation:text-shimmer 3s infinite}
@keyframes text-shimmer{0%,60%{left:-100%}100%{left:200%}}
.hero-sub{font-size:18px;color:var(--text2);line-height:1.8;margin-bottom:32px}

/* Scroll Indicator */
.hero-scroll-indicator{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:4;opacity:0.6}
.mouse-icon{width:22px;height:34px;border:2px solid var(--blue);border-radius:12px;position:relative}
.wheel{width:2px;height:6px;background:var(--blue);border-radius:2px;position:absolute;top:6px;left:50%;transform:translateX(-50%);animation:mouse-wheel 1.5s ease-in-out infinite}
.hero-scroll-indicator .mono{font-size:9px;letter-spacing:0.1em;color:var(--blue);font-weight:700}
@keyframes mouse-wheel{0%{transform:translate(-50%,0);opacity:1}100%{transform:translate(-50%,10px);opacity:0}}

.hero-ctas{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:40px}
.hero-cta-btn{font-size:16px;padding:16px 32px}

/* Hero trust grid */
.hero-trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:16px}
.trust-item{padding:20px;border:1px solid rgba(0,0,0,0.06);border-radius:16px;background:rgba(255,255,255,0.8);backdrop-filter:blur(10px);text-align:center;transition:all .3s}
.trust-item:hover{border-color:var(--blue);box-shadow:0 8px 24px rgba(10,132,255,0.1)}
.trust-item--accent{border-color:rgba(10,132,255,0.2);background:rgba(10,132,255,0.04)}
.trust-item-num{font-family:'Montserrat',sans-serif;font-size:32px;font-weight:900;background:linear-gradient(135deg,var(--blue),var(--accent));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1.2}
.trust-item-unit{font-size:16px;font-weight:700}
.trust-item-label{font-size:13px;color:var(--text2);margin-top:4px;font-weight:600}

/* Hero side */
.hero-side{display:flex;flex-direction:column;gap:16px}

/* Hero Case Study Showcase */
.hero-case-showcase{position:relative;width:100%}

/* Glow ring behind browser */
.hcs-glow-ring{position:absolute;inset:-20px;border-radius:24px;background:linear-gradient(135deg,rgba(10,132,255,0.15),rgba(191,90,242,0.1),rgba(94,92,230,0.08));filter:blur(30px);z-index:-1}

.hcs-browser{background:#fff;border:1px solid rgba(0,0,0,0.08);border-radius:16px;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,0.12),0 0 0 1px rgba(0,0,0,0.03);transition:all .6s cubic-bezier(0.2,1,0.3,1)}
.hcs-browser:hover{box-shadow:0 40px 80px rgba(10,132,255,0.15),0 0 60px rgba(10,132,255,0.06)}
.hcs-browser-bar{display:flex;align-items:center;gap:6px;padding:10px 14px;background:#f8f8f8;border-bottom:1px solid rgba(0,0,0,0.06)}
.hcs-dot{width:8px;height:8px;border-radius:50%}
.hcs-dot--red{background:#FF5F57}
.hcs-dot--yellow{background:#FFBD2E}
.hcs-dot--green{background:#28CA42}
.hcs-url{color:var(--text2);font-size:10px;margin-left:8px}
.hcs-live-badge{margin-left:auto;display:flex;align-items:center;gap:4px;font-size:9px;font-weight:800;color:#059669;letter-spacing:0.08em;font-family:'Montserrat',sans-serif}
.hcs-screen{position:relative;overflow:hidden;margin:0;padding:0;max-height:380px}
.hcs-screen img{max-width:none;width:112%;height:auto;margin-left:-6%;margin-top:-6%;padding:0;display:block;object-fit:cover;object-position:top;transition:transform 8s cubic-bezier(0.2,0.4,0.2,1)}
.hcs-browser:hover .hcs-screen img{transform:translateY(-20%)}

/* Overlay card — light mode */
.hcs-overlay-card{position:absolute;bottom:-20px;left:-20px;background:rgba(255,255,255,0.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(0,0,0,0.06);border-radius:16px;padding:16px 20px;z-index:5;min-width:240px;box-shadow:0 16px 48px rgba(0,0,0,0.08)}
.hcs-oc-badge{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.hcs-oc-badge .mono{color:var(--text2);font-size:10px;font-weight:600}
.hcs-oc-title{font-size:16px;font-weight:800;color:var(--text);margin-bottom:12px;letter-spacing:-0.01em}
.hcs-oc-stats{display:flex;align-items:center;gap:16px;margin-bottom:12px}
.hcs-stat{text-align:center}
.hcs-stat-num{font-family:'Montserrat',sans-serif;font-size:24px;font-weight:900;background:linear-gradient(135deg,var(--blue),var(--violet));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1.2}
.hcs-stat-num span{font-size:0.5em;font-weight:700}
.hcs-stat-lbl{font-size:10px;color:var(--text2);margin-top:2px;display:block;font-weight:600}
.hcs-stat-divider{width:1px;height:28px;background:rgba(0,0,0,0.08)}
.hcs-oc-tags{display:flex;gap:6px;flex-wrap:wrap}
.hcs-tag{font-size:10px;font-weight:700;color:var(--text2);background:rgba(0,0,0,0.04);border:1px solid rgba(0,0,0,0.04);padding:3px 10px;border-radius:9999px}

.side-card{background:#fff;border:1px solid rgba(0,0,0,0.06);border-radius:20px;overflow:hidden;transition:all .3s}
.side-card:hover{border-color:var(--blue);box-shadow:0 12px 32px rgba(10,132,255,0.1)}
.side-card-head{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid rgba(0,0,0,0.04)}
.side-card-head .mono{color:var(--text2);font-size:11px}
.tag-live{font-size:10px;font-weight:700;color:#059669;background:rgba(5,150,105,0.1);padding:3px 10px;border-radius:9999px;letter-spacing:0.05em}
.side-card-body{display:flex;justify-content:space-between;align-items:center;padding:16px 20px}
.side-card-body span:first-child{font-weight:700;font-size:15px}
.side-card-body .mono-num{font-size:16px;font-weight:900;color:var(--blue)}

.side-stack{display:flex;flex-direction:column;gap:12px}
.side-mini{display:flex;align-items:center;gap:14px;padding:14px 20px;background:#fff;border:1px solid rgba(0,0,0,0.06);border-radius:14px;transition:all .3s}
.side-mini:hover{border-color:var(--blue);box-shadow:0 4px 16px rgba(10,132,255,0.08)}
.mini-bar{width:4px;height:28px;border-radius:4px;background:linear-gradient(180deg,var(--blue),var(--accent))}
.mini-bar.bar-2{background:linear-gradient(180deg,var(--violet),#7C3AED)}
.mini-bar.bar-3{background:linear-gradient(180deg,#059669,#10B981)}
.mini-label{display:flex;flex-direction:column;gap:2px}
.mini-label .mono{font-size:10px;color:var(--text2)}
.mini-label span:last-child{font-size:14px;font-weight:700;color:var(--text)}

/* Hero marquee */
.hero-marquee{margin-top:48px;overflow:hidden;border-top:1px solid rgba(0,0,0,0.06);border-bottom:1px solid rgba(0,0,0,0.06);padding:16px 0}
.marquee-inner{display:flex;width:max-content;animation:marquee-scroll 30s linear infinite}
.marquee-track{display:flex;gap:0;flex-shrink:0}
.marquee-item{display:inline-flex;align-items:center;gap:8px;padding:0 24px;font-size:15px;font-weight:600;color:var(--text2);white-space:nowrap}
.mq-dot{font-size:8px}
.marquee-item:nth-child(8n+1) .mq-dot{color:#0A84FF}
.marquee-item:nth-child(8n+2) .mq-dot{color:#FF2D55}
.marquee-item:nth-child(8n+3) .mq-dot{color:#34C759}
.marquee-item:nth-child(8n+4) .mq-dot{color:#FF9F0A}
.marquee-item:nth-child(8n+5) .mq-dot{color:#BF5AF2}
.marquee-item:nth-child(8n+6) .mq-dot{color:#30B0C7}
.marquee-item:nth-child(8n+7) .mq-dot{color:#FF375F}
.marquee-item:nth-child(8n+8) .mq-dot{color:#5E5CE6}
@keyframes marquee-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ===== 02 PAIN POINT - PASTEL BLOCK LAYOUT ===== */
.pain-grid.block-layout{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:48px}
.block-layout .pain-card{padding:40px 32px;border-radius:24px;border:none;transition:transform .4s cubic-bezier(0.2,1,0.3,1);display:flex;flex-direction:column}
.block-layout .pain-card:hover{transform:translateY(-8px)}

.block-layout .pain-card[data-color="blue"]{background:#F0F7FF}
.block-layout .pain-card[data-color="violet"]{background:#F8F2FF}
.block-layout .pain-card[data-color="red"]{background:#FFF0F4}

.block-layout .pain-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}

.block-layout .pain-num{font-family:'Montserrat',sans-serif;font-size:48px;font-weight:900;line-height:1}
.block-layout .pain-card[data-color="blue"] .pain-num{color:var(--blue)}
.block-layout .pain-card[data-color="violet"] .pain-num{color:var(--violet)}
.block-layout .pain-card[data-color="red"] .pain-num{color:#FF2D55}

.block-layout .pain-en{font-size:12px;font-weight:800;padding:6px 16px;border-radius:20px;background:#fff;letter-spacing:0.02em}
.block-layout .pain-card[data-color="blue"] .pain-en{color:var(--blue);box-shadow:0 4px 12px rgba(10,132,255,0.08)}
.block-layout .pain-card[data-color="violet"] .pain-en{color:var(--violet);box-shadow:0 4px 12px rgba(191,90,242,0.08)}
.block-layout .pain-card[data-color="red"] .pain-en{color:#FF2D55;box-shadow:0 4px 12px rgba(255,45,85,0.08)}

.block-layout .pain-title{font-size:22px;font-weight:800;line-height:1.5;color:var(--text);margin-bottom:16px}

.block-layout .pain-desc{font-size:15px;color:var(--text2);line-height:1.8;margin-bottom:32px;flex-grow:1}

.block-layout .pain-foot{display:flex;align-items:center;gap:12px;font-size:14px;font-weight:700}
.block-layout .pain-arrow{width:40px;height:40px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;transition:transform .3s}
.block-layout .pain-card:hover .pain-arrow{transform:translateX(8px)}
.block-layout .pain-card[data-color="blue"] .pain-arrow{color:var(--blue);box-shadow:0 4px 12px rgba(10,132,255,0.1)}
.block-layout .pain-card[data-color="violet"] .pain-arrow{color:var(--violet);box-shadow:0 4px 12px rgba(191,90,242,0.1)}
.block-layout .pain-card[data-color="red"] .pain-arrow{color:#FF2D55;box-shadow:0 4px 12px rgba(255,45,85,0.1)}
.block-layout .pain-card[data-color="blue"] .pain-foot span{color:var(--blue)}
.block-layout .pain-card[data-color="violet"] .pain-foot span{color:var(--violet)}
.block-layout .pain-card[data-color="red"] .pain-foot span{color:#FF2D55}

.pain-after{text-align:center;padding:24px 0;border-top:1px solid rgba(0,0,0,0.06)}
.pain-after p{font-size:16px;color:var(--text2)}
.pain-after strong{color:var(--text);font-weight:800}
.pain-after .mono{color:var(--blue);font-weight:800}
.after-line{width:40px;height:2px;background:linear-gradient(90deg,var(--blue),transparent);margin:0 auto 16px;border-radius:2px}

/* ===== 03 MANIFESTO ===== */
.manifesto-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:80px;align-items:start}
.manifesto-eyebrow{color:var(--text2);margin-bottom:16px;font-size:12px}
.manifesto-headline{font-size:clamp(28px,4vw,42px);font-weight:800;line-height:1.3;margin-bottom:32px;letter-spacing:-0.02em}
.manifesto-headline span{display:block}
.manifesto-headline em{font-style:normal;background:linear-gradient(135deg,var(--blue),var(--violet));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

.manifesto-quote{position:relative;padding:24px 0;margin-bottom:24px}
.mq-mark{font-size:48px;font-weight:900;color:var(--blue);opacity:0.2;line-height:1;font-family:'Noto Sans JP'}
.mq-mark-close{text-align:right;display:block}
.manifesto-quote p{font-size:16px;line-height:1.9;color:var(--text2);padding:0 8px}
.manifesto-quote strong{color:var(--text);font-weight:800}
.manifesto-quote em{font-style:normal;color:var(--blue);font-weight:700}

.manifesto-sign .mono{color:var(--text2);font-size:13px}

/* Manifesto right */
.manifesto-vertical{display:flex;flex-direction:column;gap:0;margin-bottom:32px;text-align:center}
.manifesto-vertical span{font-size:clamp(32px,5vw,48px);font-weight:900;line-height:1.3;letter-spacing:0.1em;background:linear-gradient(135deg,var(--blue),var(--violet));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;opacity:0.15}

.manifesto-stats{background:rgba(255,255,255,0.5);backdrop-filter:blur(10px);border:1px solid rgba(0,0,0,0.06);border-radius:20px;padding:24px;overflow:hidden}
.ms-head{display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid rgba(0,0,0,0.06)}
.ms-head .mono{color:var(--text2);font-size:11px}
.ms-yr{color:var(--blue) !important}
.ms-row{display:flex;align-items:center;gap:12px;padding:8px 0}
.ms-key{font-size:14px;font-weight:700;width:60px;flex-shrink:0}
.ms-bar{flex:1;height:6px;background:rgba(0,0,0,0.06);border-radius:6px;overflow:hidden}
.ms-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--blue),var(--violet));border-radius:6px;transition:width 1.5s cubic-bezier(0.2,1,0.3,1)}
.ms-val{font-size:14px;font-weight:900;width:28px;text-align:right;color:var(--blue)}

/* ===== 04 OFFER ===== */
.section--services{background:linear-gradient(135deg,#050a14 0%,#0a1128 100%);position:relative;overflow:hidden;padding:100px 0}

.offer-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-bottom:48px}
.offer-headline-card{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);border-radius:24px;padding:40px;position:relative;overflow:hidden;transition:all .5s cubic-bezier(0.2,1,0.3,1);backdrop-filter:blur(24px)}
.offer-headline-card::before{content:'';position:absolute;inset:0;border-radius:inherit;padding:2px;background:linear-gradient(135deg,var(--blue),var(--violet),transparent);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .5s ease}
.offer-headline-card:hover{transform:translateY(-8px);box-shadow:0 32px 64px rgba(0,0,0,0.4),0 0 0 1px rgba(10,132,255,0.15)}
.offer-headline-card:hover::before{opacity:1}
.ohc-tag{color:rgba(255,255,255,0.4);margin-bottom:24px;font-size:11px}
.ohc-claim{display:flex;align-items:baseline;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.ohc-free{font-size:clamp(36px,5vw,56px);font-weight:900;background:linear-gradient(135deg,#059669,#10B981);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.ohc-x{font-size:24px;color:rgba(255,255,255,0.3);font-weight:300}
.ohc-days{font-family:'Montserrat',sans-serif;font-size:clamp(36px,5vw,56px);font-weight:900;color:#fff}
.ohc-days em{font-style:normal;font-size:0.5em;font-weight:700}
.ohc-sub{font-size:15px;color:rgba(255,255,255,0.5);line-height:1.8}
.ohc-sub strong{color:#fff}
.ohc-foot{display:flex;align-items:center;gap:10px;margin-top:24px;color:rgba(255,255,255,0.4);font-size:12px}
.pulse-dot{width:8px;height:8px;border-radius:50%;background:#10B981;animation:pulse-glow 2s ease-in-out infinite}
@keyframes pulse-glow{0%,100%{opacity:0.5;box-shadow:0 0 0 0 rgba(16,185,129,0.4)}50%{opacity:1;box-shadow:0 0 0 8px rgba(16,185,129,0)}}

.offer-list{display:flex;flex-direction:column;gap:16px;perspective:1000px}
.offer-item{display:flex;align-items:center;gap:20px;padding:20px 24px;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);border-radius:16px;transition:all .4s cubic-bezier(0.2,1,0.3,1);position:relative;z-index:1;overflow:hidden}
.offer-item::after{content:'';position:absolute;inset:0;opacity:0;transition:opacity .4s ease;z-index:-1;pointer-events:none}
.offer-item:hover{transform:scale(1.02) translateX(8px);z-index:2}
.offer-item:hover::after{opacity:1}

.offer-item[data-color="blue"] .oi-num, .offer-item[data-color="blue"] .oi-check { color: #0A84FF; }
.offer-item[data-color="violet"] .oi-num, .offer-item[data-color="violet"] .oi-check { color: #BF5AF2; }
.offer-item[data-color="red"] .oi-num, .offer-item[data-color="red"] .oi-check { color: #FF2D55; }
.offer-item[data-color="emerald"] .oi-num, .offer-item[data-color="emerald"] .oi-check { color: #34C759; }

.offer-item[data-color="blue"]:hover { background: rgba(10,132,255,0.05); border-color: rgba(10,132,255,0.3); box-shadow: 0 16px 32px rgba(0,0,0,0.3), 0 0 20px rgba(10,132,255,0.1); }
.offer-item[data-color="violet"]:hover { background: rgba(191,90,242,0.05); border-color: rgba(191,90,242,0.3); box-shadow: 0 16px 32px rgba(0,0,0,0.3), 0 0 20px rgba(191,90,242,0.1); }
.offer-item[data-color="red"]:hover { background: rgba(255,45,85,0.05); border-color: rgba(255,45,85,0.3); box-shadow: 0 16px 32px rgba(0,0,0,0.3), 0 0 20px rgba(255,45,85,0.1); }
.offer-item[data-color="emerald"]:hover { background: rgba(52,199,89,0.05); border-color: rgba(52,199,89,0.3); box-shadow: 0 16px 32px rgba(0,0,0,0.3), 0 0 20px rgba(52,199,89,0.1); }

.offer-item[data-color="blue"]::after { background: radial-gradient(circle at 100% 50%, rgba(10,132,255,0.15), transparent 50%); }
.offer-item[data-color="violet"]::after { background: radial-gradient(circle at 100% 50%, rgba(191,90,242,0.15), transparent 50%); }
.offer-item[data-color="red"]::after { background: radial-gradient(circle at 100% 50%, rgba(255,45,85,0.15), transparent 50%); }
.offer-item[data-color="emerald"]::after { background: radial-gradient(circle at 100% 50%, rgba(52,199,89,0.15), transparent 50%); }

.oi-num{font-size:16px;font-weight:900;flex-shrink:0}
.oi-body{flex:1}
.oi-body h4{font-size:16px;font-weight:700;color:#fff;margin-bottom:4px}
.oi-body p{font-size:13px;color:rgba(255,255,255,0.45);margin:0}
.oi-check{flex-shrink:0}

/* Offer band */
.offer-band{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);border-radius:24px;padding:40px;text-align:center}
.ob-row{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:32px}
.ob-stat{text-align:center}
.ob-idx{color:rgba(255,255,255,0.3);font-size:10px;display:block;margin-bottom:8px}
.ob-num{font-family:'Montserrat',sans-serif;font-size:clamp(28px,4vw,40px);font-weight:900;color:#fff;line-height:1.2;transition:color .3s}
.ob-stat[data-color="blue"] .ob-num { color: #0A84FF; }
.ob-stat[data-color="violet"] .ob-num { color: #BF5AF2; }
.ob-stat[data-color="red"] .ob-num { color: #FF2D55; }
.ob-stat[data-color="emerald"] .ob-num { color: #34C759; }
.ob-num span{font-size:0.5em;font-weight:700;color:rgba(255,255,255,0.7)}
.ob-lbl{color:rgba(255,255,255,0.4);font-size:11px;margin-top:4px}
.ob-cta{font-size:18px;padding:20px 48px}

/* ===== 05 TRUST ===== */
.trust-split{display:grid;grid-template-columns:1fr auto 1fr;gap:0;align-items:stretch;margin-bottom:48px}
.trust-card{padding:36px;border-radius:24px;background:#fff;border:1px solid rgba(0,0,0,0.06);position:relative;overflow:hidden;transition:all .4s cubic-bezier(0.2,1,0.3,1);box-shadow:0 12px 32px rgba(0,0,0,0.03);z-index:1}
.trust-card::before{content:'';position:absolute;inset:0;border-radius:inherit;padding:2px;background:linear-gradient(135deg,var(--blue),var(--accent),var(--violet));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .4s ease;pointer-events:none;z-index:2}
.trust-card:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(10,132,255,0.1),0 0 0 1px rgba(10,132,255,0.05)}
.trust-card:hover::before{opacity:1}

.tc-head{display:flex;align-items:center;gap:16px;margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid rgba(0,0,0,0.06);position:relative;z-index:3}
.tc-flag{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .3s;overflow:hidden}
.trust-card:hover .tc-flag{transform:scale(1.1) rotate(3deg)}
.tc-flag-jp{background:transparent}
.tc-flag-vn{background:transparent}
.tc-loc{color:var(--text2);font-size:11px;margin-bottom:2px}
.tc-title{font-size:20px;font-weight:800;transition:color .3s}
.trust-card:hover .tc-title{color:var(--blue)}
.tc-list{display:flex;flex-direction:column;gap:20px;position:relative;z-index:3}
.tc-list li{display:flex;gap:16px;align-items:flex-start}
.tc-list .mono-num{font-size:13px;color:var(--blue);margin-top:3px;flex-shrink:0}
.tc-list h4{font-size:15px;font-weight:700;margin-bottom:4px}
.tc-list p{font-size:13px;color:var(--text2);line-height:1.7;margin:0}

/* Trust connector */
.trust-conn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:0 24px}
.conn-dot{width:8px;height:8px;border-radius:50%;background:var(--blue);animation:pulse-glow 2s infinite}
.conn-line{width:2px;flex:1;background:linear-gradient(180deg,rgba(10,132,255,0.3),rgba(191,90,242,0.1));min-height:40px}
.conn-label{font-size:11px;color:var(--text2);white-space:nowrap}

/* Trust band */
.trust-band{background:rgba(255,255,255,0.7);backdrop-filter:blur(20px);border:1px solid rgba(0,0,0,0.06);border-radius:24px;padding:32px;box-shadow:0 12px 32px rgba(0,0,0,0.03);transition:all .3s}
.trust-band:hover{box-shadow:0 20px 48px rgba(10,132,255,0.08);border-color:var(--blue)}
.tb-row{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.tb-item{text-align:center}
.tb-idx{color:var(--text2);font-size:10px;display:block;margin-bottom:8px}
.tb-num{font-family:'Montserrat',sans-serif;font-size:32px;font-weight:900;background:linear-gradient(135deg,var(--blue),var(--accent));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1.2;transition:all .3s}
.tb-item[data-color="blue"] .tb-num { -webkit-text-fill-color: #0A84FF; }
.tb-item[data-color="violet"] .tb-num { -webkit-text-fill-color: #BF5AF2; }
.tb-item[data-color="red"] .tb-num { -webkit-text-fill-color: #FF2D55; }
.tb-item[data-color="emerald"] .tb-num { -webkit-text-fill-color: #34C759; }
.tb-num span{font-size:0.5em;font-weight:700}
.tb-lbl{color:var(--text2);font-size:12px;margin-top:4px}

/* ===== 06 PROCESS (Timeline) ===== */
.steps-timeline{max-width:900px;margin:0 auto;position:relative}
.step-row{display:flex;gap:40px;align-items:stretch;position:relative}
.step-node{display:flex;flex-direction:column;align-items:center;flex-shrink:0;width:64px;position:relative}
.step-node-ring{width:64px;height:64px;border-radius:50%;background:rgba(10,132,255,0.1);border:2px solid rgba(10,132,255,0.3);display:flex;align-items:center;justify-content:center;position:relative;z-index:2;transition:all .4s ease;flex-shrink:0}
.step-row:hover .step-node-ring{border-color:var(--blue);background:rgba(10,132,255,0.2);box-shadow:0 0 24px rgba(10,132,255,0.3)}
.step-node-num{font-family:'Montserrat',sans-serif;font-size:18px;font-weight:900;background:linear-gradient(135deg,#0A84FF,#BF5AF2);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.step-connector{width:2px;flex:1;background:linear-gradient(180deg,rgba(10,132,255,0.5),rgba(191,90,242,0.2));margin:8px 0;transform-origin:top;transform:scaleY(0);transition:transform 1s cubic-bezier(0.2,1,0.3,1) .2s}
.reveal.active .step-connector{transform:scaleY(1)}
.step-row--last .step-connector{display:none}

.step-card{flex:1;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);border-radius:24px;padding:32px;display:flex;gap:24px;align-items:flex-start;transition:all .5s cubic-bezier(0.2,1,0.3,1);margin-bottom:24px;backdrop-filter:blur(20px);position:relative;overflow:hidden}
.step-card::after{content:'';position:absolute;top:-50%;left:-100%;width:50%;height:200%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.1),transparent);transform:skewX(-20deg);pointer-events:none;opacity:0}
.step-card:hover{background:rgba(255,255,255,0.05);border-color:rgba(10,132,255,0.2);transform:translateX(8px);box-shadow:0 16px 40px rgba(0,0,0,0.3),inset 0 0 0 1px rgba(255,255,255,0.05)}
.step-card:hover::after{animation:shimmer-sweep 1s ease forwards;opacity:1}
@keyframes shimmer-sweep{0%{left:-100%}100%{left:200%}}

.step-card-icon{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 8px 24px rgba(0,0,0,0.2)}
.step-card-body{flex:1}
.step-card-top{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.step-card-top .mono-num{font-size:13px;color:var(--blue)}
.step-day{color:rgba(255,255,255,0.35);font-size:11px}
.step-card-name{font-size:24px;font-weight:900;color:#fff;margin-bottom:10px;letter-spacing:-0.02em}
.step-card-desc{font-size:15px;color:rgba(255,255,255,0.5);line-height:1.8}

/* ===== 07 CALENDAR ===== */

/* Progress Bar */
.cal-progress{margin-bottom:48px}
.cal-prog-track{display:flex;height:8px;border-radius:8px;overflow:hidden;background:rgba(0,0,0,0.04)}
.cal-prog-fill[data-phase="hearing"]{background:linear-gradient(90deg,#0A84FF,#3DA5FF);border-radius:8px 0 0 8px}
.cal-prog-fill[data-phase="design"]{background:linear-gradient(90deg,#BF5AF2,#D08CF7)}
.cal-prog-fill[data-phase="dev"]{background:linear-gradient(90deg,#059669,#34D399)}
.cal-prog-fill[data-phase="deliver"]{background:linear-gradient(90deg,#F59E0B,#FBBF24);border-radius:0 8px 8px 0}
.cal-prog-labels{display:flex;margin-top:10px}
.cal-prog-lbl{font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;letter-spacing:0.05em;color:var(--text2);text-align:center}
.cal-prog-lbl[data-phase="hearing"]{width:14.28%;color:#0A84FF}
.cal-prog-lbl[data-phase="design"]{width:42.86%;color:#BF5AF2}
.cal-prog-lbl[data-phase="dev"]{width:28.57%;color:#059669}
.cal-prog-lbl[data-phase="deliver"]{width:14.28%;color:#F59E0B}

/* Phase Cards */
.cal-phases{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:40px}
.cal-phase{background:#fff;border:1px solid rgba(0,0,0,0.06);border-radius:20px;padding:28px 24px;transition:all .4s cubic-bezier(0.2,1,0.3,1);position:relative;overflow:hidden}
.cal-phase::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;border-radius:20px 20px 0 0;transition:height .3s ease}
.cal-phase[data-phase="hearing"]::before{background:linear-gradient(90deg,#0A84FF,#3DA5FF)}
.cal-phase[data-phase="design"]::before{background:linear-gradient(90deg,#BF5AF2,#D08CF7)}
.cal-phase[data-phase="dev"]::before{background:linear-gradient(90deg,#059669,#34D399)}
.cal-phase[data-phase="deliver"]::before{background:linear-gradient(90deg,#F59E0B,#FBBF24)}
.cal-phase:hover{transform:translateY(-6px);box-shadow:0 20px 48px rgba(0,0,0,0.08);border-color:transparent}
.cal-phase:hover::before{height:6px}

/* Phase Head */
.cal-phase-head{display:flex;align-items:center;gap:16px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgba(0,0,0,0.06)}
.cal-phase-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cal-phase[data-phase="hearing"] .cal-phase-icon{background:rgba(10,132,255,0.1);color:#0A84FF}
.cal-phase[data-phase="design"] .cal-phase-icon{background:rgba(191,90,242,0.1);color:#BF5AF2}
.cal-phase[data-phase="dev"] .cal-phase-icon{background:rgba(5,150,105,0.1);color:#059669}
.cal-phase[data-phase="deliver"] .cal-phase-icon{background:rgba(245,158,11,0.1);color:#F59E0B}
.cal-phase-range{font-size:11px;font-weight:800;letter-spacing:0.1em;display:block;margin-bottom:2px}
.cal-phase[data-phase="hearing"] .cal-phase-range{color:#0A84FF}
.cal-phase[data-phase="design"] .cal-phase-range{color:#BF5AF2}
.cal-phase[data-phase="dev"] .cal-phase-range{color:#059669}
.cal-phase[data-phase="deliver"] .cal-phase-range{color:#F59E0B}
.cal-phase-name{font-size:20px;font-weight:900;color:var(--text);letter-spacing:-0.02em}

/* Phase Day List */
.cal-phase-list{list-style:none;padding:0;margin:0 0 16px}
.cal-phase-list li{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid rgba(0,0,0,0.03);font-size:14px;color:var(--text);transition:all .2s}
.cal-phase-list li:last-child{border-bottom:none}
.cal-phase-list li:hover{padding-left:4px}
.cal-li-day{font-size:13px;font-weight:800;min-width:24px}
.cal-phase[data-phase="hearing"] .cal-li-day{color:#0A84FF}
.cal-phase[data-phase="design"] .cal-li-day{color:#BF5AF2}
.cal-phase[data-phase="dev"] .cal-li-day{color:#059669}
.cal-phase[data-phase="deliver"] .cal-li-day{color:#F59E0B}
.cal-li-txt{font-size:13px;font-weight:600;color:var(--text)}
.cal-li-key{font-weight:700}
.cal-li-key .cal-li-txt{font-weight:800}

/* Milestone */
.cal-phase-milestone{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:10px;background:rgba(0,0,0,0.02);border:1px dashed rgba(0,0,0,0.08)}
.cal-ms-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.cal-phase[data-phase="hearing"] .cal-ms-dot{background:#0A84FF;box-shadow:0 0 8px rgba(10,132,255,0.4)}
.cal-phase[data-phase="design"] .cal-ms-dot{background:#BF5AF2;box-shadow:0 0 8px rgba(191,90,242,0.4)}
.cal-phase[data-phase="dev"] .cal-ms-dot{background:#059669;box-shadow:0 0 8px rgba(5,150,105,0.4)}
.cal-phase[data-phase="deliver"] .cal-ms-dot{background:#F59E0B;box-shadow:0 0 8px rgba(245,158,11,0.4)}
.cal-ms-txt{font-size:12px;font-weight:800;letter-spacing:0.05em;color:var(--text2)}
.cal-ms-final{border-style:solid;background:rgba(245,158,11,0.05);border-color:rgba(245,158,11,0.2)}
.cal-ms-final .cal-ms-txt{color:#F59E0B}

.cal-foot,.cases-foot{text-align:center;padding-top:24px}
.cf-rule{width:40px;height:2px;background:linear-gradient(90deg,var(--blue),transparent);margin:0 auto 16px;border-radius:2px}
.cal-foot p,.cases-foot p{font-size:15px;color:var(--text2)}
.cal-foot strong,.cases-foot strong{color:var(--text);font-weight:800}
.cal-foot .mono,.cases-foot .mono{color:var(--blue);font-weight:800}

/* ===== 08 CASE STUDY ===== */
.cs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-bottom:40px}
.cs-card{border-radius:20px;overflow:hidden;background:#fff;border:1px solid rgba(0,0,0,0.06);transition:all .5s cubic-bezier(0.2,1,0.3,1);box-shadow:0 8px 32px rgba(0,0,0,0.06);display:flex;flex-direction:column}
.cs-card:hover{transform:translateY(-8px);box-shadow:0 24px 60px rgba(10,132,255,0.12),0 0 0 1px rgba(10,132,255,0.08)}

/* Browser Chrome */
.cs-browser{overflow:hidden}
.cs-bar{display:flex;align-items:center;gap:6px;padding:10px 14px;background:#f8f8f8;border-bottom:1px solid rgba(0,0,0,0.06)}
.cs-dot{width:8px;height:8px;border-radius:50%}
.cs-dot--red{background:#FF5F57}
.cs-dot--yellow{background:#FFBD2E}
.cs-dot--green{background:#28CA42}
.cs-url{color:var(--text2);font-size:10px;margin-left:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:160px}
.cs-live-badge{margin-left:auto;display:flex;align-items:center;gap:4px;font-size:9px;font-weight:800;color:#059669;letter-spacing:0.08em}
.pulse-dot-sm{width:6px;height:6px;border-radius:50%;background:#10B981;animation:pulse-glow 2s ease-in-out infinite;flex-shrink:0}

/* Mock Screen → Real Image */
.cs-screen{height:200px;position:relative;overflow:hidden;background:#f0f0f0}
.cs-screen img{width:100%;min-height:100%;display:block;object-fit:cover;object-position:top left;transition:transform 6s cubic-bezier(0.2,0.4,0.2,1)}
.cs-card:hover .cs-screen img{transform:translateY(-30%)}

/* Card Body */
.cs-body{padding:24px;flex:1;display:flex;flex-direction:column}
.cs-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.cs-tag{font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;padding:4px 12px;border-radius:9999px;letter-spacing:0.03em;transition:all .3s}
.cs-tag[data-color="blue"]{color:#0A84FF;background:rgba(10,132,255,0.08)}
.cs-tag[data-color="violet"]{color:#BF5AF2;background:rgba(191,90,242,0.08)}
.cs-tag[data-color="red"]{color:#FF2D55;background:rgba(255,45,85,0.08)}
.cs-tag[data-color="emerald"]{color:#34C759;background:rgba(52,199,89,0.08)}
.cs-tag[data-color="amber"]{color:#F59E0B;background:rgba(245,158,11,0.08)}
.cs-card:hover .cs-tag[data-color="blue"]{background:#0A84FF;color:#fff}
.cs-card:hover .cs-tag[data-color="violet"]{background:#BF5AF2;color:#fff}
.cs-card:hover .cs-tag[data-color="red"]{background:#FF2D55;color:#fff}
.cs-card:hover .cs-tag[data-color="emerald"]{background:#34C759;color:#fff}
.cs-card:hover .cs-tag[data-color="amber"]{background:#F59E0B;color:#fff}
.cs-duration{font-size:12px;color:var(--text2);display:flex;align-items:center;gap:4px}
.cs-title{font-size:18px;font-weight:800;margin-bottom:8px;color:var(--text);transition:color .3s;letter-spacing:-0.02em}
.cs-card:hover .cs-title{color:var(--blue)}
.cs-desc{font-size:13px;color:var(--text2);line-height:1.7;margin-bottom:16px;flex:1}

/* Result Badge */
.cs-result{display:flex;align-items:center;gap:10px;padding:12px 16px;background:rgba(0,0,0,0.02);border-radius:12px;border:1px solid rgba(0,0,0,0.04);margin-top:auto}
.cs-result-num{font-size:20px;font-weight:900;letter-spacing:-0.02em}
.cs-result-num[data-color="blue"]{color:#0A84FF}
.cs-result-num[data-color="violet"]{color:#BF5AF2}
.cs-result-num[data-color="red"]{color:#FF2D55}
.cs-result-num[data-color="emerald"]{color:#34C759}
.cs-result-num[data-color="amber"]{color:#F59E0B}
.cs-result-lbl{font-size:12px;color:var(--text2);font-weight:600}

/* ===== 09 INDUSTRIES — Circle Ring ===== */
.ind-ring-wrap{position:relative;width:100%;max-width:560px;aspect-ratio:1;margin:0 auto;overflow:visible;padding:60px}
.ind-ring-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:5}
.ind-ring-num{font-size:64px;font-weight:900;display:block;background:linear-gradient(135deg,#0A84FF,#BF5AF2);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1}
.ind-ring-label{font-size:14px;font-weight:700;color:var(--text2);display:block;margin-top:4px}
.ind-ring-svg{position:absolute;inset:0;width:100%;height:100%;z-index:1}
.ind-ring-active{opacity:0.3;animation:ring-spin 30s linear infinite}
@keyframes ring-spin{to{stroke-dashoffset:-1400}}

/* Orbit nodes */
.ind-orbit-node{position:absolute;top:50%;left:50%;width:56px;height:56px;margin:-28px 0 0 -28px;z-index:4;transform:rotate(var(--angle)) translateY(-220px) rotate(calc(-1 * var(--angle)));transition:transform .3s ease}
.ind-orbit-node:hover{transform:rotate(var(--angle)) translateY(-220px) rotate(calc(-1 * var(--angle))) scale(1.2)}
.ind-orb-icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#fff;border:2px solid rgba(0,0,0,0.06);box-shadow:0 4px 16px rgba(0,0,0,0.06);transition:all .3s;cursor:default}
.ind-orbit-node[data-color="blue"] .ind-orb-icon{color:#0A84FF}
.ind-orbit-node[data-color="violet"] .ind-orb-icon{color:#BF5AF2}
.ind-orbit-node[data-color="emerald"] .ind-orb-icon{color:#34C759}
.ind-orbit-node[data-color="red"] .ind-orb-icon{color:#FF2D55}
.ind-orbit-node[data-color="amber"] .ind-orb-icon{color:#F59E0B}
.ind-orbit-node[data-color="blue"]:hover .ind-orb-icon{background:#0A84FF;color:#fff;border-color:#0A84FF;box-shadow:0 8px 24px rgba(10,132,255,0.3)}
.ind-orbit-node[data-color="violet"]:hover .ind-orb-icon{background:#BF5AF2;color:#fff;border-color:#BF5AF2;box-shadow:0 8px 24px rgba(191,90,242,0.3)}
.ind-orbit-node[data-color="emerald"]:hover .ind-orb-icon{background:#34C759;color:#fff;border-color:#34C759;box-shadow:0 8px 24px rgba(52,199,89,0.3)}
.ind-orbit-node[data-color="red"]:hover .ind-orb-icon{background:#FF2D55;color:#fff;border-color:#FF2D55;box-shadow:0 8px 24px rgba(255,45,85,0.3)}
.ind-orbit-node[data-color="amber"]:hover .ind-orb-icon{background:#F59E0B;color:#fff;border-color:#F59E0B;box-shadow:0 8px 24px rgba(245,158,11,0.3)}

/* Always-visible label */
.ind-orb-tooltip{position:absolute;left:50%;transform:translateX(-50%);background:rgba(255,255,255,0.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:8px 14px;border-radius:12px;white-space:nowrap;z-index:10;text-align:center;pointer-events:none;transition:all .25s;border:1px solid rgba(0,0,0,0.06);box-shadow:0 4px 16px rgba(0,0,0,0.05)}
.ind-orb-tooltip strong{display:block;font-size:12px;font-weight:800;color:var(--text)}
.ind-orb-tooltip span{font-size:10px;color:var(--text2)}
/* Position: top half nodes show label below, bottom half show above */
.ind-orbit-node[style*="0deg"] .ind-orb-tooltip,
.ind-orbit-node[style*="45deg"] .ind-orb-tooltip,
.ind-orbit-node[style*="315deg"] .ind-orb-tooltip{top:calc(100% + 6px)}
.ind-orbit-node[style*="90deg"] .ind-orb-tooltip{left:calc(100% + 10px);top:50%;transform:translateX(0) translateY(-50%);text-align:left}
.ind-orbit-node[style*="270deg"] .ind-orb-tooltip{right:calc(100% + 10px);left:auto;top:50%;transform:translateY(-50%);text-align:right}
.ind-orbit-node[style*="135deg"] .ind-orb-tooltip,
.ind-orbit-node[style*="180deg"] .ind-orb-tooltip,
.ind-orbit-node[style*="225deg"] .ind-orb-tooltip{bottom:calc(100% + 6px);top:auto}
.ind-orbit-node:hover .ind-orb-tooltip strong{color:var(--blue)}

/* ===== 10 VALUES — Stacked Accordion ===== */
.val-stack{display:flex;flex-direction:column;gap:0;max-width:800px;margin:0 auto;position:relative}
.val-card{background:#fff;border:1px solid rgba(0,0,0,0.06);border-radius:20px;padding:28px 32px;cursor:pointer;transition:all .5s cubic-bezier(0.2,1,0.3,1);position:relative;overflow:hidden;box-shadow:0 4px 16px rgba(0,0,0,0.04)}
.val-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:20px 0 0 20px}
.val-card[data-color="blue"]::before{background:#0A84FF}
.val-card[data-color="violet"]::before{background:#BF5AF2}
.val-card[data-color="emerald"]::before{background:#34C759}
.val-card[data-color="red"]::before{background:#FF2D55}
.val-card[data-color="amber"]::before{background:#F59E0B}
.val-card+.val-card{margin-top:-8px}
.val-card:nth-child(2){margin-left:16px;margin-right:-16px}
.val-card:nth-child(3){margin-left:32px;margin-right:-32px}
.val-card:nth-child(4){margin-left:16px;margin-right:-16px}
.val-card:nth-child(5){margin-left:0}
.val-card:hover{transform:translateX(8px);box-shadow:0 16px 48px rgba(0,0,0,0.1);z-index:5}

/* Card header */
.val-head{display:flex;align-items:center;gap:16px}
.val-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .3s}
.val-card[data-color="blue"] .val-icon{background:rgba(10,132,255,0.08);color:#0A84FF}
.val-card[data-color="violet"] .val-icon{background:rgba(191,90,242,0.08);color:#BF5AF2}
.val-card[data-color="emerald"] .val-icon{background:rgba(52,199,89,0.08);color:#34C759}
.val-card[data-color="red"] .val-icon{background:rgba(255,45,85,0.08);color:#FF2D55}
.val-card[data-color="amber"] .val-icon{background:rgba(245,158,11,0.08);color:#F59E0B}
.val-card:hover .val-icon{transform:scale(1.1)}

.val-head-text{flex:1;min-width:0}
.val-num{font-size:10px;color:var(--text2);display:block;margin-bottom:2px}
.val-card[data-color="blue"] .val-num{color:#0A84FF}
.val-card[data-color="violet"] .val-num{color:#BF5AF2}
.val-card[data-color="emerald"] .val-num{color:#34C759}
.val-card[data-color="red"] .val-num{color:#FF2D55}
.val-card[data-color="amber"] .val-num{color:#F59E0B}
.val-name{font-size:17px;font-weight:800;color:var(--text);transition:color .3s}
.val-card:hover .val-name{color:var(--blue)}
.val-stat{font-family:'Montserrat',sans-serif;font-size:28px;font-weight:900;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;flex-shrink:0;margin-left:auto}
.val-card[data-color="blue"] .val-stat{background:linear-gradient(135deg,#0A84FF,#3DA5FF)}
.val-card[data-color="violet"] .val-stat{background:linear-gradient(135deg,#BF5AF2,#D08CF7)}
.val-card[data-color="emerald"] .val-stat{background:linear-gradient(135deg,#34C759,#6ADF8A)}
.val-card[data-color="red"] .val-stat{background:linear-gradient(135deg,#FF2D55,#FF6B8A)}
.val-card[data-color="amber"] .val-stat{background:linear-gradient(135deg,#F59E0B,#FBBF24)}

/* Expandable detail */
.val-detail{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(0.2,1,0.3,1)}
.val-card:hover .val-detail{max-height:100px}
.val-detail-inner{padding-top:16px;padding-left:64px}
.val-detail-inner p{font-size:14px;color:var(--text2);line-height:1.7}
.val-detail-inner .mono{font-size:11px;color:var(--text2);margin-bottom:4px;display:block}

/* ===== 11 FAQ ===== */
.faq-header{text-align:center;margin-bottom:64px}
.faq-header .section-title{margin-bottom:16px}
.faq-desc{color:var(--text2);font-size:18px;margin:0 auto;line-height:1.8;max-width:800px}
.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:16px}
.faq-item{background:#fff;border:1px solid rgba(0,0,0,0.06);border-radius:24px;overflow:hidden;transition:all .4s cubic-bezier(0.2,1,0.3,1);box-shadow:0 4px 16px rgba(0,0,0,0.02);position:relative;z-index:1}
.faq-item::before{content:'';position:absolute;inset:0;border-radius:inherit;padding:2px;background:linear-gradient(135deg,var(--blue),var(--accent));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .4s ease;pointer-events:none;z-index:2}
.faq-item:hover{box-shadow:0 16px 40px rgba(10,132,255,0.08);transform:translateY(-2px)}
.faq-item:hover::before{opacity:1}
.faq-item.open{box-shadow:0 24px 60px rgba(10,132,255,0.12);transform:translateY(-4px);background:linear-gradient(135deg,#ffffff 0%,#f4f8ff 100%);z-index:10}
.faq-item.open::before{opacity:1;background:linear-gradient(135deg,var(--blue),var(--violet))}
.faq-question{width:100%;padding:28px 32px;display:flex;align-items:center;gap:20px;background:none;border:none;cursor:pointer;font-family:inherit;text-align:left;color:var(--text);font-size:17px;font-weight:700;line-height:1.5;letter-spacing:0.01em;transition:color .3s ease;position:relative;z-index:3}
.faq-question:hover{color:var(--blue)}
.faq-question-num{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,rgba(10,132,255,0.08),rgba(94,92,230,0.08));display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:'Montserrat',sans-serif;font-size:14px;font-weight:800;color:var(--blue);transition:all .4s}
.faq-item.open .faq-question-num{background:linear-gradient(135deg,var(--blue),var(--accent));color:#fff;box-shadow:0 4px 16px rgba(10,132,255,0.3);transform:scale(1.05)}
.faq-question-text{flex:1}
.faq-question-icon{width:28px;height:28px;border-radius:50%;background:rgba(0,0,0,0.04);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .4s;position:relative;margin-left:auto}
.faq-question-icon::before,.faq-question-icon::after{content:'';position:absolute;background:var(--text2);border-radius:2px;transition:all .3s ease}
.faq-question-icon::before{width:12px;height:2px}
.faq-question-icon::after{width:2px;height:12px}
.faq-item.open .faq-question-icon{background:rgba(10,132,255,0.1);transform:rotate(45deg)}
.faq-item.open .faq-question-icon::before,.faq-item.open .faq-question-icon::after{background:var(--blue)}
.faq-item.open .faq-question{color:var(--blue)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(0.4,0,0.2,1)}
.faq-item.open .faq-answer{max-height:300px}
.faq-answer p{padding:0 32px 28px 92px;color:var(--text2);font-size:15px;line-height:1.9;margin:0}
.faq-cta{text-align:center;margin-top:40px;font-size:15px;color:var(--text2)}

/* ===== 12 CONTACT ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.inquiry-bullets{list-style:none;margin:0 0 32px;padding:0}
.inquiry-bullets li{color:rgba(255,255,255,0.65);font-size:15px;padding:8px 0;display:flex;align-items:center;gap:10px}
.inquiry-bullets .mono{color:var(--blue);font-weight:800;font-size:14px}
.inquiry-meta{display:flex;flex-direction:column;gap:16px;padding:20px 0;border-top:1px solid rgba(255,255,255,0.08)}
.inquiry-meta>div{display:flex;align-items:center;gap:16px}
.inquiry-meta .mono{color:rgba(255,255,255,0.35);font-size:11px;width:50px}
.meta-val{color:rgba(255,255,255,0.7);font-size:14px;font-weight:600}

.contact-form-wrap{padding:32px;background:rgba(255,255,255,0.05);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.08);border-radius:24px}
.form-head{margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,0.08)}
.fh-tag{color:var(--blue);font-size:11px;margin-bottom:4px}
.fh-title{font-size:22px;font-weight:800;color:#fff}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-group--wide{grid-column:span 2}
.form-group label{display:block;margin-bottom:8px;font-size:14px;font-weight:700;color:#fff}
.form-group .req{color:var(--blue)}
.form-group input[type="text"],.form-group input[type="email"],.form-group select,.form-group textarea{width:100%;padding:14px 16px;border-radius:12px;border:1px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.05);color:#fff;font-family:inherit;font-size:15px;transition:border-color .3s ease;appearance:none;-webkit-appearance:none}
.form-group select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.4)' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.form-group select option{background:#1a1a2e;color:#fff}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(255,255,255,0.25)}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:rgba(10,132,255,0.5)}
.form-group textarea{resize:vertical;min-height:100px}
.char-count{color:rgba(255,255,255,0.25);font-size:11px;margin-top:6px;text-align:right}

.form-foot{margin-top:24px}
.form-consent{color:rgba(255,255,255,0.3);font-size:11px;margin-bottom:16px}
.form-submit{width:100%;justify-content:center;border:none;font-size:18px;padding:20px}

/* ===== 13 FOOTER ===== */
.site-footer{background:#050a14;color:#fff;padding:60px 0 32px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-logo{display:flex;align-items:center;gap:8px;margin-bottom:16px}
.footer-logo .logo-mark{font-size:24px}
.footer-logo .logo-text{font-size:12px}
.footer-tagline{color:rgba(255,255,255,0.45);font-size:13px;line-height:1.8;max-width:320px}
.footer-col h4{font-size:14px;font-weight:700;color:rgba(255,255,255,0.8);margin-bottom:16px}
.footer-col ul{display:flex;flex-direction:column;gap:8px}
.footer-col li{font-size:13px;color:rgba(255,255,255,0.45)}
.footer-link{color:rgba(255,255,255,0.55);text-decoration:none;transition:color .2s}
.footer-link:hover{color:var(--blue)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid rgba(255,255,255,0.06)}
.footer-bottom span{font-size:12px;color:rgba(255,255,255,0.3)}

/* ===== Mouse Glow ===== */
.mouse-glow{position:fixed;width:600px;height:600px;background:radial-gradient(circle,rgba(10,132,255,0.08) 0%,transparent 70%);border-radius:50%;pointer-events:none;z-index:0;left:-1000px;top:-1000px}

/* ===== Reveal Animation ===== */
.reveal{opacity:0;transform:translateY(30px);transition:all 0.8s cubic-bezier(0.2,1,0.3,1)}
.reveal.active{opacity:1;transform:translateY(0)}

/* ===== Toast ===== */
#toast-container{position:fixed;top:32px;right:32px;z-index:9999;display:flex;flex-direction:column;gap:16px;pointer-events:none}
.toast{background:rgba(255,255,255,0.95);backdrop-filter:blur(20px);color:var(--text);padding:16px 24px;border-radius:16px;font-weight:600;font-size:15px;box-shadow:0 20px 40px rgba(0,0,0,0.08),inset 0 0 0 1px rgba(0,0,0,0.05);transform:translateX(120%) scale(0.9);opacity:0;transition:all 0.5s cubic-bezier(0.68,-0.55,0.27,1.55);pointer-events:auto;display:flex;align-items:center;gap:14px;position:relative;overflow:hidden}
.toast::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px}
.toast.show{transform:translateX(0) scale(1);opacity:1}
.toast.error::before{background:linear-gradient(180deg,#EF4444,#F97316)}
.toast.success::before{background:linear-gradient(180deg,#10B981,#059669)}
.toast-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;flex-shrink:0}
.toast.error .toast-icon{background:rgba(239,68,68,0.2);color:#EF4444}
.toast.success .toast-icon{background:rgba(16,185,129,0.2);color:#10B981}

/* ===== Hamburger ===== */
.menu-toggle{display:none;background:transparent;border:none;color:var(--text);font-size:28px;line-height:1;cursor:pointer;padding:8px;border-radius:8px;transition:background .2s}
.menu-toggle:hover{background:rgba(0,0,0,0.05)}

/* ===== CREATIVE ENHANCEMENTS ===== */

/* Hero particles canvas */
.hero-particles{position:absolute;inset:0;z-index:0;pointer-events:none}

/* Animated grid background */
.hero-grid-bg{position:absolute;inset:0;z-index:0;pointer-events:none;background-image:
  linear-gradient(rgba(10,132,255,0.05) 1px,transparent 1px),
  linear-gradient(90deg,rgba(10,132,255,0.05) 1px,transparent 1px);
background-size:40px 40px;animation:grid-drift 20s linear infinite;opacity:0.6}
@keyframes grid-drift{0%{background-position:0 0}100%{background-position:40px 40px}}

/* Third orb */
.hero-orb-3{width:350px;height:350px;background:rgba(94,92,230,0.1);top:40%;left:30%;animation:orb-float 8s ease-in-out infinite}
@keyframes orb-float{0%,100%{transform:translate(0,0)}33%{transform:translate(30px,-20px)}66%{transform:translate(-20px,15px)}}
.hero-orb-1{animation:orb-float 12s ease-in-out infinite reverse}
.hero-orb-2{animation:orb-float 10s ease-in-out infinite 2s}

/* Floating stickers */
.hero-stickers{position:absolute;inset:0;pointer-events:none;z-index:4}
.sticker{position:absolute;padding:8px 16px;font-size:12px;font-weight:800;border-radius:12px;white-space:nowrap;backdrop-filter:blur(10px);border:1px solid rgba(0,0,0,0.06);box-shadow:0 8px 24px rgba(0,0,0,0.08)}
.st-1{top:15%;right:8%;background:rgba(10,132,255,0.08);color:var(--blue);animation:sticker-float 6s ease-in-out infinite;transform:rotate(-4deg)}
.st-2{top:55%;right:3%;background:rgba(5,150,105,0.08);color:#059669;animation:sticker-float 7s ease-in-out infinite 1s;transform:rotate(3deg)}
.st-3{bottom:20%;left:5%;background:rgba(191,90,242,0.08);color:var(--violet);animation:sticker-float 8s ease-in-out infinite 2s;transform:rotate(-6deg)}
@keyframes sticker-float{0%,100%{transform:translateY(0) rotate(var(--r,0deg))}50%{transform:translateY(-15px) rotate(var(--r,0deg))}}
.st-1{--r:-4deg}.st-2{--r:3deg}.st-3{--r:-6deg}

/* Typing cursor */
.typing-cursor{display:inline-block;width:3px;height:1em;background:var(--blue);margin-left:4px;vertical-align:text-bottom;animation:blink-cursor 1s step-end infinite}
@keyframes blink-cursor{0%,100%{opacity:1}50%{opacity:0}}

/* Wave dividers */
.wave-divider{position:relative;z-index:2;margin-top:-1px;line-height:0}
.wave-divider svg{display:block;width:100%;height:60px}
.wave-1 svg{height:80px}

/* Gradient border glow */
.glow-border{position:relative}
.glow-border::before{content:'';position:absolute;inset:-2px;border-radius:26px;background:linear-gradient(135deg,var(--blue),var(--violet),#059669,var(--blue));background-size:400% 400%;animation:gradient-rotate 4s ease infinite;z-index:-1;opacity:0.5;filter:blur(4px)}
@keyframes gradient-rotate{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

/* Stagger reveal delays */
.reveal-text-wrap{overflow:hidden;display:block}
.reveal-text{display:block;transform:translateY(110%);transition:transform 1s cubic-bezier(0.16,1,0.3,1)}
.reveal.active .reveal-text{transform:translateY(0)}
.reveal[class*="reveal"]:nth-child(1){transition-delay:0s}
.reveal[class*="reveal"]:nth-child(2){transition-delay:0.1s}
.reveal[class*="reveal"]:nth-child(3){transition-delay:0.2s}
.reveal[class*="reveal"]:nth-child(4){transition-delay:0.3s}
.reveal[class*="reveal"]:nth-child(5){transition-delay:0.4s}
.reveal[class*="reveal"]:nth-child(6){transition-delay:0.5s}

/* Pain card hover gradient line */
.pain-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue),var(--violet));transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.pain-card:hover::after{transform:scaleX(1)}

/* Offer item entrance line */
.offer-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;opacity:0;transition:opacity .3s}
.offer-item[data-color="blue"]::before { background: linear-gradient(180deg, #0A84FF, transparent); }
.offer-item[data-color="violet"]::before { background: linear-gradient(180deg, #BF5AF2, transparent); }
.offer-item[data-color="red"]::before { background: linear-gradient(180deg, #FF2D55, transparent); }
.offer-item[data-color="emerald"]::before { background: linear-gradient(180deg, #34C759, transparent); }
.offer-item{position:relative}
.offer-item:hover::before{opacity:1}


/* Trust card shimmer */
.trust-card{position:relative;overflow:hidden}
.trust-card::after{content:'';position:absolute;top:-50%;left:-100%;width:40%;height:200%;background:linear-gradient(90deg,transparent,rgba(10,132,255,0.08),transparent);transform:skewX(-15deg);pointer-events:none;opacity:0}
.trust-card:hover::after{animation:shimmer-sweep 1.2s ease forwards}

/* Stat bar animation trigger */
.ms-bar span{width:0 !important}
.ms-bar.animated span{width:var(--w) !important;transition:width 1.5s cubic-bezier(0.2,1,0.3,1)}

/* Enhanced hero headline glow */
.hero-num{position:relative}
.hero-num::after{content:attr(data-text);position:absolute;left:0;top:0;filter:blur(24px);opacity:0.3;pointer-events:none;background:linear-gradient(135deg,#0A84FF,#BF5AF2);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* Contact form glow focus */
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{box-shadow:0 0 0 3px rgba(10,132,255,0.15)}

/* Footer gradient line */
.footer-bottom{position:relative}
.footer-bottom::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(10,132,255,0.3),transparent)}

/* Section title animated underline on hover */
.section-title{position:relative;display:inline-block}

/* ===== Background Decorations (AI & Design) ===== */
.bg-decor-container {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 0;
}

.decor-svg {
  position: absolute;
  pointer-events: none;
  z-index: 0;
  user-select: none;
  opacity: 0.04;
  transition: opacity 0.5s ease, transform 0.5s ease;
}

/* Light sections styling */
.section:not(.section--services) .decor-svg {
  opacity: 0.04;
}

/* Dark sections styling (Offer, Process) */
.section--services .decor-svg {
  opacity: 0.08;
  filter: drop-shadow(0 0 12px rgba(10, 132, 255, 0.3));
}

/* Colors for SVGs */
.decor-svg .color-blue { stroke: var(--blue); fill: none; }
.decor-svg .color-violet { stroke: var(--violet); fill: none; }
.decor-svg .color-accent { stroke: var(--accent); fill: none; }
.decor-svg .fill-blue { fill: var(--blue); stroke: none; }
.decor-svg .fill-violet { fill: var(--violet); stroke: none; }
.decor-svg .fill-accent { fill: var(--accent); stroke: none; }

/* Semi-transparent colors for dark sections */
.section--services .decor-svg .color-blue { stroke: rgba(10, 132, 255, 0.6); }
.section--services .decor-svg .color-violet { stroke: rgba(191, 90, 242, 0.6); }
.section--services .decor-svg .color-accent { stroke: rgba(94, 92, 230, 0.6); }

/* Hover effects */
.section:hover .decor-svg {
  opacity: 0.08;
}
.section--services:hover .decor-svg {
  opacity: 0.14;
}

/* Animations */
.anim-float {
  animation: float-slow 15s ease-in-out infinite;
}
.anim-float-reverse {
  animation: float-slow-reverse 18s ease-in-out infinite;
}
.anim-rotate {
  animation: rotate-slow 45s linear infinite;
}
.anim-rotate-reverse {
  animation: rotate-slow 50s linear infinite reverse;
}
.anim-pulse {
  animation: pulse-slow 8s ease-in-out infinite;
}

@keyframes float-slow {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50% { transform: translateY(-20px) rotate(4deg); }
}

@keyframes float-slow-reverse {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50% { transform: translateY(20px) rotate(-4deg); }
}

@keyframes rotate-slow {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

@keyframes pulse-slow {
  0%, 100% { opacity: 0.4; }
  50% { opacity: 0.9; }
}

/* Positions for section background elements */
/* Hero Section */
.decor-hero-1 { top: 10%; left: 4%; width: 240px; height: 240px; }
.decor-hero-2 { bottom: 15%; right: 4%; width: 280px; height: 280px; }
.decor-hero-3 { top: 32%; right: 28%; width: 150px; height: 150px; }

/* Problem Section */
.decor-prob-1 { top: 12%; left: 6%; width: 180px; height: 180px; }
.decor-prob-2 { bottom: 12%; right: 6%; width: 200px; height: 200px; }

/* Philosophy Section */
.decor-phil-1 { top: 18%; right: 10%; width: 300px; height: 220px; }
.decor-phil-2 { bottom: 8%; left: 8%; width: 180px; height: 180px; }

/* Offer Section (Dark bg) */
.decor-off-1 { top: 5%; left: 3%; width: 360px; height: 360px; }
.decor-off-2 { bottom: 5%; right: 3%; width: 340px; height: 340px; }

/* Trust Section */
.decor-tru-1 { top: 12%; right: 12%; width: 220px; height: 220px; }
.decor-tru-2 { bottom: 8%; left: 10%; width: 240px; height: 240px; }

/* Process Section (Dark bg) */
.decor-proc-1 { top: 20%; left: 5%; width: 220px; height: 220px; }
.decor-proc-2 { bottom: 15%; right: 5%; width: 240px; height: 240px; }

/* Calendar Section */
.decor-cal-1 { top: 15%; left: 4%; width: 220px; height: 220px; }
.decor-cal-2 { bottom: 10%; right: 4%; width: 260px; height: 260px; }

/* Responsive adjustments */
@media (max-width: 768px) {
  .decor-svg {
    opacity: 0.015 !important;
    transform: scale(0.7) !important;
  }
}

/* =========================================
   RESPONSIVE
   ========================================= */

/* TABLET (≤1024px) */
@media(max-width:1024px){
  .section{padding:80px 0}
  .container{padding:0 24px}
  .hero{min-height:auto;padding:100px 0 40px}
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-side{display:grid;grid-template-columns:1fr 1fr;gap:16px}
  .side-stack{grid-column:span 1;flex-direction:column}
  .section-title{font-size:36px}
  .manifesto-grid{grid-template-columns:1fr;gap:48px}
  .offer-grid{grid-template-columns:1fr}
  .trust-split{grid-template-columns:1fr;gap:24px}
  .trust-conn{flex-direction:row;padding:12px 0}
  .conn-line{height:2px;width:auto;flex:1;min-height:auto}
  .contact-grid{grid-template-columns:1fr;gap:48px}
  .cal-phases{grid-template-columns:repeat(2,1fr)}
  .cs-grid{grid-template-columns:repeat(2,1fr)}
  .ind-ring-wrap{max-width:420px;padding:50px}
  .ind-orbit-node{width:48px;height:48px;margin:-24px 0 0 -24px;transform:rotate(var(--angle)) translateY(-160px) rotate(calc(-1 * var(--angle)))}
  .ind-orbit-node:hover{transform:rotate(var(--angle)) translateY(-160px) rotate(calc(-1 * var(--angle))) scale(1.12)}
  .ind-orb-icon{width:48px;height:48px}
  .ind-ring-svg circle{r:160}
  .ind-orb-tooltip{padding:5px 8px;border-radius:8px}
  .ind-orb-tooltip strong{font-size:10px}
  .ind-orb-tooltip span{display:none}
  .ind-ring-num{font-size:48px}
  .val-card{padding:22px 24px}
  .val-name{font-size:15px}
  .val-stat{font-size:24px}
  .val-detail-inner{padding-left:56px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .steps-timeline{max-width:100%}
  .ob-row{grid-template-columns:repeat(4,1fr)}
}

/* MOBILE (≤768px) */
@media(max-width:768px){
  html,body{overflow-x:hidden}
  .section{padding:60px 0;scroll-margin-top:60px}
  .container{padding:0 20px}

  .site-header{height:60px;padding:0 24px;display:flex;justify-content:space-between;align-items:center;width:100%}
  .site-header.scrolled{height:56px}
  .logo-img{height:36px}
  .logo-mark{font-size:22px}
  .logo-text{font-size:11px}
  .menu-toggle{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;font-size:24px}
  .nav-cta-desktop{display:inline-flex;height:36px;padding:0 14px;font-size:13px;margin-right:4px}
  #main-nav{position:fixed;top:60px;left:0;right:0;bottom:0;background:rgba(255,255,255,0.98);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);flex-direction:column;gap:0;padding:16px 0 24px;box-shadow:0 12px 32px rgba(0,0,0,0.1);transform:translateY(-10px);opacity:0;visibility:hidden;pointer-events:none;transition:all .3s cubic-bezier(0.2,1,0.3,1);overflow-y:auto;z-index:999}
  #main-nav.open{transform:translateY(0);opacity:1;visibility:visible;pointer-events:auto}
  .nav-link{display:flex;align-items:center;min-height:48px;padding:0 24px;font-size:16px;font-weight:700;border-bottom:1px solid rgba(0,0,0,0.04);transition:background .2s,color .2s}
  .nav-link:active{background:rgba(10,132,255,0.06)}
  .nav-link:last-of-type{border-bottom:none}
  #main-nav::after{content:'';display:block;padding:8px 24px 0}
  #main-nav .nav-cta{display:flex;align-items:center;justify-content:center;margin:16px 24px 0;height:52px;font-size:16px;border-radius:14px;width:calc(100% - 48px)}

  .hero{padding:80px 0 32px}
  .hero-stickers{display:none}
  .hero-shapes{display:none}
  .hcs-3d .hcs-browser{transform:translateY(0);animation:mobile-float 6s ease-in-out infinite}
  @keyframes mobile-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
  .hcs-glow-ring{display:none}
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .hero-side{grid-template-columns:1fr}
  .hero-ctas{flex-direction:column;width:100%}
  .hero-cta-btn{width:100%;text-align:center;justify-content:center}
  .hero-trust-grid{grid-template-columns:repeat(3,1fr);gap:10px}
  .trust-item{padding:14px 10px}
  .trust-item-num{font-size:24px}

  .section-title{font-size:28px;line-height:1.3}
  .section-sub{font-size:15px}

  .pain-grid.block-layout{grid-template-columns:1fr;gap:16px}
  .block-layout .pain-card{padding:24px 20px;border-radius:20px}
  .block-layout .pain-top{margin-bottom:20px}
  .block-layout .pain-num{font-size:36px}
  .block-layout .pain-en{font-size:11px;padding:4px 12px}
  .block-layout .pain-title{font-size:18px;margin-bottom:12px}
  .block-layout .pain-desc{font-size:14px;margin-bottom:24px}
  .manifesto-headline{font-size:24px}
  .offer-grid{grid-template-columns:1fr}
  .ob-row{grid-template-columns:repeat(2,1fr);gap:16px}
  .trust-split{grid-template-columns:1fr}
  .tb-row{grid-template-columns:repeat(2,1fr);gap:16px}

  .step-node{width:40px}
  .step-node-ring{width:40px;height:40px}
  .step-node-num{font-size:13px}
  .step-row{gap:14px}
  .step-card{flex-direction:column;padding:20px;gap:14px;margin-bottom:16px}
  .step-card-name{font-size:18px}
  .step-card-desc{font-size:14px}

  .cal-phases{grid-template-columns:1fr}
  .cal-phase{padding:24px 20px}

  .cs-grid{grid-template-columns:1fr}

  /* Industries: switch to list on mobile */
  .ind-ring-wrap{aspect-ratio:auto;max-width:100%;display:flex;flex-direction:column;gap:10px;padding:0;overflow:visible}
  .ind-ring-center{position:relative;top:auto;left:auto;transform:none;margin-bottom:12px}
  .ind-ring-num{font-size:36px}
  .ind-ring-svg{display:none}
  .ind-orbit-node{position:relative;top:auto;left:auto;width:100%;height:auto;margin:0;transform:none !important;display:flex;align-items:center;gap:12px;background:#fff;border:1px solid rgba(0,0,0,0.06);border-radius:14px;padding:12px 16px;border-left:3px solid transparent;overflow:hidden}
  .ind-orbit-node[data-color="blue"]{border-left-color:#0A84FF}
  .ind-orbit-node[data-color="violet"]{border-left-color:#BF5AF2}
  .ind-orbit-node[data-color="emerald"]{border-left-color:#34C759}
  .ind-orbit-node[data-color="red"]{border-left-color:#FF2D55}
  .ind-orbit-node[data-color="amber"]{border-left-color:#F59E0B}
  .ind-orbit-node:hover{transform:none !important}
  .ind-orb-icon{width:36px;height:36px;flex-shrink:0;border:none;box-shadow:none}
  .ind-orb-icon svg{width:18px;height:18px}
  .ind-orb-tooltip{position:relative;left:auto;top:auto;bottom:auto;right:auto;transform:none !important;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;border:none;box-shadow:none;padding:0;text-align:left;pointer-events:auto;flex:1;min-width:0}
  .ind-orb-tooltip strong{display:block;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}
  .ind-orb-tooltip span{display:block;font-size:12px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

  /* Values: compact on mobile */
  .val-card:nth-child(2),.val-card:nth-child(3),.val-card:nth-child(4){margin-left:0;margin-right:0}
  .val-card+.val-card{margin-top:0}
  .val-card{padding:16px 18px;border-radius:16px}
  .val-head{gap:12px;align-items:flex-start}
  .val-icon{width:40px;height:40px;border-radius:10px;margin-top:2px}
  .val-icon svg{width:20px;height:20px}
  .val-head-text{flex:1;min-width:0}
  .val-name{font-size:15px;line-height:1.4;white-space:normal;word-break:keep-all}
  .val-stat{font-size:22px;margin-top:2px}
  .val-num{font-size:10px}
  .val-detail-inner{padding-left:52px}
  .val-detail-inner p{font-size:13px}

  .faq-question{font-size:14px;padding:18px 16px;gap:12px}
  .faq-question-num{width:32px;height:32px;font-size:11px;border-radius:8px}
  .faq-answer p{padding:0 16px 20px 60px;font-size:13px}

  .contact-grid{grid-template-columns:1fr;gap:40px}
  .contact-form-wrap{padding:20px}
  .form-grid{grid-template-columns:1fr}
  .form-group--wide{grid-column:span 1}

  .footer-grid{grid-template-columns:1fr;gap:32px}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}

  .mouse-glow{display:none}
}

/* SMALL MOBILE (≤480px) */
@media(max-width:480px){
  .container{padding:0 16px}
  .section{padding:48px 0}
  .hero{padding:72px 0 24px}
  .hero-line{font-size:22px}
  .hero-num{font-size:48px}
  .section-title{font-size:24px}

  .cal-phases{grid-template-columns:1fr}

  .ob-row{grid-template-columns:repeat(2,1fr)}
  .ob-num{font-size:28px}

  .val-card{padding:16px}
  .val-head{gap:10px}
  .val-icon{width:32px;height:32px;border-radius:8px;margin-top:0}
  .val-icon svg{width:16px;height:16px}
  .val-name{font-size:14px}
  .val-stat{font-size:18px;margin-top:0}
  .val-detail-inner{padding-left:42px}
  .val-detail-inner p{font-size:12px}
  
  .ind-orbit-node{padding:10px 14px;gap:10px}
  .ind-orb-icon{width:32px;height:32px}
  .ind-orb-icon svg{width:16px;height:16px}
  .ind-orb-tooltip strong{font-size:13px}
  .ind-orb-tooltip span{font-size:11px}

  .hero-trust-grid{grid-template-columns:1fr 1fr 1fr;gap:8px}
  .trust-item-num{font-size:20px}

  #toast-container{top:16px;right:16px;left:16px}
  .toast{font-size:14px;padding:14px 18px}
}

/* Touch devices */
@media(hover:none) and (pointer:coarse){
  .glass-card:hover,.step-card:hover,.faq-item:hover,.nav-cta:hover,.btn-grad:hover,.val-card:hover,.cs-card:hover,.ind-orbit-node:hover,.cal-phase:hover,.side-card:hover,.side-mini:hover,.trust-item:hover,.offer-item:hover{transform:none !important;box-shadow:var(--shadow) !important}
  
  /* Tactile feedback on touch */
  .btn-grad:active,.nav-cta:active,.val-card:active,.ind-orbit-node:active,.cs-card:active,.faq-item:active,.step-card:active,.trust-card:active{transform:scale(0.98) !important;transition-duration:0.15s !important;opacity:0.9}
  
  .mouse-glow{display:none}
}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none}
  .marquee-inner{animation:none}
}
