/* KOWA Solutions — site styles
 * Built on top of tokens.css. Keeps every visual rule from the existing
 * landing page (kit.css), and adds new rules for the briefing flow,
 * service detail pages, contact page and floating CTA.
 * ---------------------------------------------------------------- */
@import url('./tokens.css');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-sans);font-size:16px;line-height:1.6;color:var(--fg);background:var(--bg);overflow-x:hidden;transition:background .35s cubic-bezier(.4,0,.2,1),color .35s cubic-bezier(.4,0,.2,1)}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit;cursor:pointer}
ul{list-style:none}
button{font-family:inherit}
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 24px}
.section{padding:120px 0}
.section-narrow{padding:80px 0}

/* ---------- Section heads ---------- */
.section-head{text-align:center;margin-bottom:64px}
.section-head--left{text-align:left;margin-bottom:48px}
.section-tag{display:inline-block;font-size:13px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--kowa-orange);margin-bottom:16px;position:relative;padding-left:20px}
.section-tag::before{content:'';position:absolute;left:0;top:50%;width:10px;height:2px;background:var(--kowa-orange);transform:translateY(-50%)}
.section-title{font-size:clamp(32px,5vw,48px);font-weight:800;line-height:1.15;color:var(--heading);margin-bottom:16px;letter-spacing:-.02em}
.section-desc{font-size:18px;color:var(--fg-muted);max-width:560px;margin:0 auto;line-height:1.6}
.section-head--left .section-title,.section-head--left .section-desc{margin-left:0}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:inherit;font-weight:600;font-size:15px;border:none;cursor:pointer;transition:.35s cubic-bezier(.4,0,.2,1);border-radius:8px;white-space:nowrap;text-align:center}
.btn-primary{background:var(--kowa-orange);color:#fff;padding:14px 28px}
.btn-primary:hover{transform:translateY(-2px)}
.btn-primary:disabled{opacity:.55;cursor:not-allowed;transform:none}
.glow-btn{box-shadow:0 4px 24px rgba(255,106,43,.35)}
.btn-ghost{background:transparent;color:var(--heading);padding:14px 28px;border:1.5px solid var(--border-ui-strong)}
.btn-ghost:hover{border-color:var(--kowa-orange);color:var(--kowa-orange);transform:translateY(-2px)}
.btn-ghost-inv{background:transparent;color:#fff;padding:14px 28px;border:1.5px solid rgba(255,255,255,.25)}
.btn-ghost-inv:hover{border-color:var(--kowa-orange);color:var(--kowa-orange);transform:translateY(-2px)}
.btn-nav{background:var(--kowa-orange);color:#fff;padding:10px 22px;border-radius:8px}
.btn-nav.btn-nav-ghost{background:transparent;color:var(--heading);border:1.5px solid var(--border-ui-strong);padding:8.5px 18px}
.btn-nav.btn-nav-ghost:hover{border-color:var(--kowa-orange);color:var(--kowa-orange)}
.btn-full{width:100%;justify-content:center;padding:16px 28px;font-size:16px;border-radius:14px}
.btn-lg{padding:18px 32px;font-size:16px;border-radius:12px}
.btn-link{display:inline-flex;align-items:center;gap:8px;color:var(--kowa-orange);font-weight:600;font-size:15px;cursor:pointer;border-bottom:1px solid transparent;transition:.2s}
.btn-link:hover{border-bottom-color:var(--kowa-orange);transform:translateX(2px)}

/* ---------- Nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:12px 0;transition:.35s cubic-bezier(.4,0,.2,1)}
.nav.scrolled{background:var(--nav-scrolled);backdrop-filter:blur(20px) saturate(1.4);box-shadow:var(--nav-shadow);padding:10px 0}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-logo{display:flex;align-items:center;gap:12px}
/* Pill dimensions fixed in both themes — only colors change in dark mode (no size jump) */
.nav-logo-icon{
  position:relative;
  isolation:isolate;
  display:inline-flex;
  align-items:center;
  padding:10px 26px;
  border-radius:999px;
  background:transparent;
  box-shadow:none;
  transition:background .35s cubic-bezier(.4,0,.2,1),box-shadow .35s cubic-bezier(.4,0,.2,1);
}
.nav-logo-icon::after{
  content:'';
  position:absolute;
  inset:-6px -12px;
  border-radius:999px;
  background:transparent;
  z-index:-1;
  pointer-events:none;
  transition:background .35s cubic-bezier(.4,0,.2,1);
}
.nav-logo-icon img{height:120px;width:auto;max-width:none;display:block;flex-shrink:0}
[data-theme="dark"] .nav-logo-icon{
  background:linear-gradient(180deg,#fff 0%,#f4f7fa 100%);
  box-shadow:0 10px 28px rgba(0,0,0,.2),0 0 0 1px rgba(255,255,255,.25) inset;
}
[data-theme="dark"] .nav-logo-icon::after{
  background:radial-gradient(ellipse 100% 80% at 50% 50%,rgba(255,255,255,.35) 0%,transparent 72%);
}
.nav-logo-text{display:flex;flex-direction:column;line-height:1.2}
.nav-brand{font-weight:700;font-size:20px;color:var(--heading)}
.nav-sub{font-size:13px;color:var(--fg-muted)}
.nav-links{display:flex;align-items:center;gap:22px;flex-shrink:1;min-width:0;flex-wrap:nowrap}
.nav-links a:not(.btn){font-size:14px;font-weight:500;color:var(--fg-muted);position:relative;transition:.35s cubic-bezier(.4,0,.2,1);white-space:nowrap;flex-shrink:0}
.nav-links a:not(.btn)::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--kowa-orange);transition:.35s cubic-bezier(.4,0,.2,1);border-radius:1px}
.nav-links a:not(.btn):hover,.nav-links a:not(.btn).active{color:var(--heading)}
.nav-links a:not(.btn):hover::after,.nav-links a:not(.btn).active::after{width:100%}
.nav-cta-row{display:flex;gap:10px;align-items:center;flex-shrink:0;margin-left:4px}
.nav-dropdown{position:relative;flex-shrink:0}
.nav-dropdown-trigger{
  display:inline-flex;align-items:center;gap:6px;
  font-size:14px;font-weight:500;color:var(--fg-muted);
  background:transparent;border:none;cursor:pointer;padding:0;
  font-family:inherit;white-space:nowrap;position:relative;
  transition:.35s cubic-bezier(.4,0,.2,1);
}
.nav-dropdown-trigger::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--kowa-orange);transition:.35s cubic-bezier(.4,0,.2,1);border-radius:1px}
.nav-dropdown-trigger:hover,.nav-dropdown-trigger.active,.nav-dropdown.is-active .nav-dropdown-trigger{color:var(--heading)}
.nav-dropdown-trigger:hover::after,.nav-dropdown-trigger.active::after,.nav-dropdown.is-active .nav-dropdown-trigger::after{width:100%}
.nav-dropdown-chevron{
  width:8px;height:8px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;
  transform:rotate(45deg) translateY(-2px);transition:transform .25s ease;opacity:.7;
}
.nav-dropdown.is-open .nav-dropdown-chevron{transform:rotate(-135deg) translateY(1px)}
.nav-dropdown-panel{
  position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(6px);
  min-width:240px;padding:8px;background:var(--surface-card);
  border:1px solid var(--border-ui);border-radius:14px;box-shadow:var(--shadow-lg);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .2s ease,transform .2s ease,visibility .2s;
  z-index:1100;
}
.nav-dropdown.is-open .nav-dropdown-panel{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.nav-dropdown-item{
  display:flex;flex-direction:column;align-items:flex-start;gap:2px;width:100%;
  padding:12px 14px;border:none;border-radius:10px;background:transparent;
  cursor:pointer;text-align:left;font-family:inherit;transition:background .2s ease;
}
.nav-dropdown-item strong{font-size:14px;font-weight:600;color:var(--heading)}
.nav-dropdown-item span{font-size:12px;color:var(--fg-muted);line-height:1.4}
.nav-dropdown-item:hover,.nav-dropdown-item.active{background:var(--bg-alt)}
.nav-mobile-projects{border-bottom:1px solid var(--border-ui)}
.nav-mobile-projects-trigger{
  display:flex;align-items:center;justify-content:space-between;width:100%;
  font-size:17px;font-weight:500;color:var(--heading);padding:12px 0;
  background:transparent;border:none;cursor:pointer;font-family:inherit;
}
.nav-mobile-projects-trigger.active{color:var(--kowa-orange)}
.nav-mobile-projects-panel{display:none;flex-direction:column;padding:0 0 8px 12px;gap:2px}
.nav-mobile-projects.is-open .nav-mobile-projects-panel{display:flex}
.nav-mobile-projects-panel a{font-size:15px!important;font-weight:500!important;color:var(--fg-muted)!important;padding:10px 0!important;border-bottom:none!important}
.nav-mobile-projects-panel a.active{color:var(--kowa-orange)!important}

/* Mobile hamburger */
.nav-toggle{display:none;background:transparent;border:none;cursor:pointer;width:40px;height:40px;align-items:center;justify-content:center;color:var(--heading)}
.nav-mobile{display:none}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:140px 0 80px;overflow:hidden;background:var(--hero-gradient)}
.hero-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.hero-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5;animation:orbFloat 8s ease-in-out infinite}
.hero-orb-1{width:500px;height:500px;background:radial-gradient(circle,rgba(255,106,43,.18),transparent 70%);top:-10%;right:-5%}
.hero-orb-2{width:600px;height:600px;background:radial-gradient(circle,rgba(26,58,92,.15),transparent 70%);bottom:-15%;left:-10%;animation-delay:-3s}
.hero-orb-3{width:350px;height:350px;background:radial-gradient(circle,rgba(255,106,43,.12),transparent 70%);top:40%;left:30%;animation-delay:-5s}
@keyframes orbFloat{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(20px,-30px) scale(1.05)}66%{transform:translate(-15px,20px) scale(.97)}}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:2}
.hero-eyebrow{margin-bottom:20px}
.hero-title{font-size:clamp(36px,4.5vw,56px);font-weight:800;line-height:1.12;color:var(--heading);letter-spacing:-.03em;margin-bottom:20px}
.hero-accent{background:linear-gradient(135deg,var(--kowa-orange),var(--kowa-orange-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-subtitle{font-size:19px;color:var(--fg-muted);margin-bottom:32px;line-height:1.5;max-width:520px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:32px}
.hero-ctas .btn{flex:1 1 0;min-width:240px;justify-content:center}
.hero-trust{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--fg-muted)}
.trust-dot{width:8px;height:8px;border-radius:50%;background:var(--kowa-orange);box-shadow:0 0 8px rgba(255,106,43,.55);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 8px rgba(255,106,43,.35)}50%{box-shadow:0 0 20px rgba(255,106,43,.55)}}

/* Hero terminal */
.hero-visual{position:relative;display:flex;justify-content:center}
.hero-terminal{position:relative;width:380px;border-radius:20px}
.hero-terminal-glass{position:absolute;inset:-1px;border-radius:20px;background:linear-gradient(135deg,rgba(11,27,43,.95),rgba(22,45,70,.9));border:1px solid rgba(255,255,255,.08);box-shadow:0 16px 64px rgba(11,27,43,.2),0 0 60px rgba(11,27,43,.3)}
.hero-terminal-body{position:relative;z-index:1}
.terminal-bar{display:flex;align-items:center;gap:7px;padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.06)}
.terminal-dot{width:11px;height:11px;border-radius:50%}
.terminal-dot--red{background:#ff5f57}.terminal-dot--yellow{background:#febc2e}.terminal-dot--green{background:#28c840}
.terminal-title{margin-left:auto;font-size:12px;font-family:var(--font-mono);color:rgba(255,255,255,.3);letter-spacing:.5px}
.terminal-screen{padding:20px 20px 24px;font-family:var(--font-mono);font-size:13.5px;line-height:1.9;color:rgba(224,230,237,.85);min-height:220px}
.terminal-line{white-space:nowrap}
.terminal-prompt{color:var(--kowa-orange);font-weight:700;margin-right:8px}
.terminal-typed{color:#fff;border-right:2px solid var(--kowa-orange);padding-right:2px}
.terminal-accent{color:var(--kowa-orange);font-weight:600}
.terminal-success{color:#28c840;font-weight:700}
.terminal-dim{color:rgba(224,230,237,.4)}
.terminal-tag{display:inline-block;padding:1px 8px;border-radius:4px;background:rgba(255,106,43,.12);color:var(--kowa-orange-light);font-size:12px;margin:0 2px}
.terminal-cursor{color:var(--kowa-orange);animation:blink 1s step-end infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.hero-float{position:absolute;display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:30px;background:var(--float-badge-bg);backdrop-filter:blur(12px);box-shadow:var(--shadow-md);font-size:12px;font-weight:600;color:var(--heading);animation:floatBadge 4s ease-in-out infinite;z-index:5}
.hero-float-1{top:15%;left:-20px}
.hero-float-2{bottom:10%;right:-30px;animation-delay:-2s}
@keyframes floatBadge{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* ---------- Services overview ---------- */
.services{background:var(--bg-alt)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.svc-card{position:relative;border-radius:20px;transition:.35s cubic-bezier(.4,0,.2,1);cursor:pointer;text-align:left}
.svc-card:hover{transform:translateY(-6px)}
.svc-card-body{padding:36px 28px;background:var(--surface-card);border-radius:20px;border:1px solid var(--border-ui);transition:.35s cubic-bezier(.4,0,.2,1);height:100%;display:flex;flex-direction:column}
.svc-card:hover .svc-card-body{box-shadow:var(--shadow-lg);border-color:rgba(255,106,43,.2)}
.svc-icon{width:64px;height:64px;margin-bottom:24px}
.svc-card h3{font-size:22px;font-weight:700;color:var(--heading);margin-bottom:12px}
.svc-card p{font-size:15px;color:var(--fg-muted);line-height:1.6;margin-bottom:20px}
.svc-simple{background:rgba(255,106,43,.04);border-left:3px solid var(--kowa-orange);padding:12px 14px;border-radius:0 8px 8px 0;font-size:14px;color:var(--fg);line-height:1.65;margin-bottom:20px}
.svc-list{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}
.svc-list li{font-size:14px;color:var(--fg);font-weight:500;padding-left:18px;position:relative}
.svc-list li::before{content:'';position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:50%;background:var(--kowa-orange)}
.svc-card-link{margin-top:auto;color:var(--kowa-orange);font-weight:600;font-size:14px;display:inline-flex;align-items:center;gap:6px;transition:.2s}
.svc-card:hover .svc-card-link{transform:translateX(4px)}

/* ---------- About ---------- */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-content .section-tag{margin-bottom:12px}
.about-content .section-title{text-align:left;margin-bottom:20px}
.about-text{font-size:17px;color:var(--fg-muted);line-height:1.7;margin-bottom:32px}
.about-list{display:flex;flex-direction:column;gap:20px}
.about-list li{display:flex;gap:16px;align-items:flex-start}
.about-list-icon{width:36px;height:36px;min-width:36px;border-radius:8px;background:rgba(255,106,43,.08);display:flex;align-items:center;justify-content:center;margin-top:2px}
.about-list li strong{display:block;font-size:15px;font-weight:600;color:var(--heading);margin-bottom:2px}
.about-list li span{font-size:14px;color:var(--fg-muted);line-height:1.5}
.about-visual{display:flex;justify-content:center}
.about-portrait{position:relative;width:280px}
.about-portrait-glow{position:absolute;inset:-20px;border-radius:30px;background:radial-gradient(circle,rgba(255,106,43,.12),transparent 70%);filter:blur(20px);animation:glowPulse 3s ease-in-out infinite}
@keyframes glowPulse{0%,100%{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}
.about-portrait-frame{position:relative;border-radius:28px;overflow:hidden;border:2px solid rgba(255,106,43,.15);box-shadow:0 16px 64px rgba(11,27,43,.14);background:var(--kowa-navy);aspect-ratio:3/4}
.about-portrait-img img{display:block;width:100%;height:100%;object-fit:cover;object-position:top center}
.about-stat{position:absolute;display:flex;flex-direction:column;align-items:center;padding:12px 18px;border-radius:14px;background:var(--float-badge-bg);backdrop-filter:blur(12px);box-shadow:var(--shadow-md);z-index:3;animation:floatBadge 5s ease-in-out infinite}
.about-stat-val{font-size:22px;font-weight:800;color:var(--kowa-orange);line-height:1}
.about-stat-lbl{font-size:11px;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}
.about-stat-1{top:-15px;right:-30px}
.about-stat-2{bottom:60px;left:-40px;animation-delay:-1.5s}
.about-stat-3{bottom:-15px;right:-20px;animation-delay:-3s}

/* ---------- Process ---------- */
.process{background:var(--bg-alt)}
.process-timeline{position:relative;max-width:760px;margin:0 auto}
.process-line{position:absolute;top:0;left:28px;width:3px;height:100%;background:var(--border-ui);border-radius:3px}
.process-line-fill{width:100%;background:linear-gradient(180deg,var(--kowa-orange),var(--kowa-orange-light));border-radius:3px;transition:height .3s ease}
.process-steps{display:flex;flex-direction:column;gap:48px;position:relative;z-index:1}
.process-step{display:flex;gap:28px;align-items:flex-start;cursor:pointer}
.process-marker{width:58px;height:58px;min-width:58px;border-radius:50%;background:var(--surface-card);border:2px solid var(--border-ui-strong);display:flex;align-items:center;justify-content:center;transition:.35s cubic-bezier(.4,0,.2,1);z-index:2}
.process-marker span{font-size:16px;font-weight:700;color:var(--fg-muted);transition:.35s}
.process-step.active .process-marker{background:var(--kowa-orange);border-color:var(--kowa-orange);box-shadow:0 0 40px rgba(255,106,43,.35)}
.process-step.active .process-marker span{color:#fff}
.process-body h3{font-size:20px;font-weight:700;color:var(--heading);margin-bottom:6px}
.process-body p{font-size:15px;color:var(--fg-muted);line-height:1.6}

/* ---------- Results ---------- */
.results{background:var(--kowa-navy)}
.results .section-title{color:#fff}
.results .section-desc{color:var(--fg-inv);opacity:.7}
.results-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.res-card{border-radius:20px;transition:.35s}
.res-card:hover{transform:translateY(-6px)}
.res-card-inner{height:100%;padding:36px 28px;background:linear-gradient(165deg,rgba(26,58,92,.5),rgba(11,27,43,.8));border:1px solid rgba(255,255,255,.06);border-radius:20px;backdrop-filter:blur(10px)}
.res-card:hover .res-card-inner{border-color:rgba(255,106,43,.2)}
.res-metric{margin-bottom:4px}
.res-metric-num,.res-metric-text{font-size:48px;font-weight:900;color:var(--kowa-orange);line-height:1;letter-spacing:-.03em}
.res-metric-sym{font-size:28px;font-weight:700;color:var(--kowa-orange)}
.res-metric-lbl{display:block;font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--kowa-orange-light);margin-bottom:16px;font-weight:500}
.res-card h3{font-size:20px;font-weight:700;color:#fff;margin-bottom:10px}
.res-card p{font-size:14px;color:var(--fg-inv);opacity:.7;line-height:1.6}

/* ---------- FAQ ---------- */
.faq-list{max-width:780px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border-ui)}
.faq-question{display:flex;align-items:center;justify-content:space-between;padding:20px 0;font-size:17px;font-weight:600;color:var(--heading);cursor:pointer;list-style:none;gap:16px}
.faq-question::-webkit-details-marker{display:none}
.faq-question::after{content:'+';font-size:22px;color:var(--kowa-orange);font-weight:400;flex-shrink:0}
.faq-item[data-open="true"] .faq-question::after{content:'−'}
.faq-answer{padding:0 0 24px;font-size:16px;color:var(--fg-muted);line-height:1.7;max-width:640px}

/* ---------- Footer ---------- */
.footer{background:var(--bg-dark);padding:64px 0 32px}
.footer-grid{display:grid;grid-template-columns:1.35fr repeat(4,1fr);gap:36px;margin-bottom:48px}
.section--alt{background:var(--bg-alt)}
.footer-brand-block{display:flex;flex-direction:column;gap:12px;max-width:300px}
.footer-brand-row{display:flex;align-items:center;gap:12px}
.footer-brand-row img{
  height:60px;width:auto;max-width:none;flex-shrink:0;
  padding:10px 18px;border-radius:999px;
  background:var(--footer-logo-bg);
  box-shadow:none;
  transition:background .35s cubic-bezier(.4,0,.2,1),box-shadow .35s cubic-bezier(.4,0,.2,1);
}
[data-theme="dark"] .footer-brand-row img{
  box-shadow:0 6px 20px rgba(0,0,0,.18),0 0 0 1px rgba(255,255,255,.15) inset;
}
.footer-brand-row strong{font-size:16px;color:#fff;font-weight:700}
.footer-brand-row span{font-size:12px;color:var(--fg-inv);opacity:.5;display:block;line-height:1.3}
.footer-tagline{font-size:14px;color:var(--fg-inv);opacity:.7;line-height:1.6;margin-top:8px}
.footer-col h4{font-size:13px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:18px}
.footer-col a{display:block;font-size:14px;color:var(--fg-inv);opacity:.65;padding:6px 0;transition:.2s}
.footer-col a:hover{opacity:1;color:var(--kowa-orange)}
.footer-bar{padding-top:24px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.footer-bar-meta{font-size:13px;color:var(--fg-inv);opacity:.5}
.footer-bar-legal{display:flex;gap:24px}
.footer-bar-legal a{font-size:13px;color:var(--fg-inv);opacity:.6}
.footer-bar-legal a:hover{opacity:1;color:var(--kowa-orange)}

/* ---------- Sticky floating CTA ---------- */
.sticky-cta{position:fixed;bottom:24px;right:24px;z-index:900;display:flex;align-items:center;gap:10px;background:var(--kowa-orange);color:#fff;padding:14px 22px;border-radius:999px;box-shadow:0 8px 32px rgba(255,106,43,.45),0 4px 16px rgba(11,27,43,.18);font-weight:600;font-size:14px;cursor:pointer;transition:.35s cubic-bezier(.4,0,.2,1);transform:translateY(80px);opacity:0;pointer-events:none}
.sticky-cta.visible{transform:translateY(0);opacity:1;pointer-events:auto}
.sticky-cta:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(255,106,43,.55)}
.sticky-cta-pulse{position:absolute;inset:0;border-radius:999px;border:2px solid var(--kowa-orange);animation:stickyPulse 2.4s ease-out infinite;pointer-events:none}
@keyframes stickyPulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.18);opacity:0}}

/* ---------- Service Detail page ---------- */
.svc-hero{position:relative;padding:160px 0 80px;overflow:hidden;background:var(--hero-gradient)}
.svc-hero-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.svc-hero-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.45}
.svc-hero-orb-1{width:520px;height:520px;background:radial-gradient(circle,rgba(255,106,43,.18),transparent 70%);top:-15%;right:-8%;animation:orbFloat 8s ease-in-out infinite}
.svc-hero-orb-2{width:420px;height:420px;background:radial-gradient(circle,rgba(26,58,92,.14),transparent 70%);bottom:-20%;left:-5%;animation:orbFloat 10s ease-in-out infinite -3s}
.svc-hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center}
.svc-hero h1{font-size:clamp(36px,4.5vw,52px);font-weight:800;line-height:1.12;color:var(--heading);letter-spacing:-.03em;margin:14px 0 20px}
.svc-hero-lead{font-size:19px;color:var(--fg-muted);line-height:1.55;margin-bottom:32px;max-width:540px}
.svc-hero-icon-card{position:relative;display:flex;align-items:center;justify-content:center;padding:48px;border-radius:28px;background:var(--surface-card);border:1px solid var(--border-ui);box-shadow:var(--shadow-md);aspect-ratio:1;width:100%;max-width:380px;margin:0 auto}
.svc-hero-icon-card svg{width:140px;height:140px}
.svc-hero-icon-card::before{content:'';position:absolute;inset:-1px;border-radius:28px;background:linear-gradient(135deg,rgba(255,106,43,.4),transparent 50%,rgba(11,27,43,.15));z-index:-1;filter:blur(20px);opacity:.6}

.svc-block{padding:100px 0}
.svc-block:nth-of-type(even){background:var(--bg-alt)}
.svc-two{display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:start}
.svc-two h2{font-size:32px;font-weight:800;color:var(--heading);letter-spacing:-.02em;margin-bottom:16px;line-height:1.2}
.svc-two p{font-size:16px;color:var(--fg-muted);line-height:1.7;margin-bottom:16px}
.svc-features{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.svc-feature{padding:24px;background:var(--surface-card);border:1px solid var(--border-ui);border-radius:14px;transition:.3s}
.svc-feature:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:rgba(255,106,43,.18)}
.svc-feature-icon{width:32px;height:32px;border-radius:8px;background:rgba(255,106,43,.08);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.svc-feature h4{font-size:15px;font-weight:700;color:var(--heading);margin-bottom:6px}
.svc-feature p{font-size:14px;color:var(--fg-muted);line-height:1.55;margin:0}

/* "for whom / when" pill list */
.svc-pill-list{display:flex;flex-direction:column;gap:14px}
.svc-pill{display:flex;align-items:flex-start;gap:14px;padding:18px 20px;border-radius:14px;background:var(--surface-card);border:1px solid var(--border-ui)}
.svc-pill-icon{width:32px;height:32px;min-width:32px;border-radius:8px;background:rgba(255,106,43,.08);display:flex;align-items:center;justify-content:center}
.svc-pill strong{display:block;font-size:15px;font-weight:600;color:var(--heading);margin-bottom:2px}
.svc-pill span{font-size:14px;color:var(--fg-muted);line-height:1.5}

/* svc CTA banner */
.svc-cta-banner{background:var(--kowa-navy);position:relative;overflow:hidden}
.svc-cta-banner::before{content:'';position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(255,106,43,.16),transparent 70%);filter:blur(80px);right:-10%;top:-30%;pointer-events:none}
.svc-cta-banner .container{position:relative;z-index:1}
.svc-cta-banner-inner{display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:center;padding:80px 0}
.svc-cta-banner h2{font-size:clamp(28px,3.5vw,40px);font-weight:800;color:#fff;letter-spacing:-.02em;line-height:1.2;margin-bottom:14px}
.svc-cta-banner p{font-size:17px;color:var(--fg-inv);opacity:.75;line-height:1.6;max-width:520px}
.svc-cta-banner-actions{display:flex;flex-direction:column;gap:12px;align-items:flex-end}
.svc-cta-banner--slim .svc-cta-banner-inner--slim{display:flex;justify-content:space-between;align-items:center;gap:24px;padding:36px 0;flex-wrap:wrap}

/* ---------- Page hero (for non-home pages) ---------- */
.page-hero{padding:160px 0 80px;background:var(--page-gradient);text-align:center;position:relative;overflow:hidden}
.page-hero-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.page-hero-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;background:radial-gradient(circle,rgba(255,106,43,.18),transparent 70%);width:500px;height:500px;top:-30%;left:50%;transform:translateX(-50%);animation:orbFloat 10s ease-in-out infinite}
.page-hero h1{font-size:clamp(36px,5vw,52px);font-weight:800;line-height:1.12;color:var(--heading);letter-spacing:-.03em;margin:14px 0 18px;position:relative;z-index:1}
.page-hero p{font-size:19px;color:var(--fg-muted);line-height:1.55;max-width:620px;margin:0 auto;position:relative;z-index:1}

/* ---------- Contact page ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:60px;align-items:flex-start}
.contact-info .section-tag{margin-bottom:12px}
.contact-info .section-title{text-align:left;margin-bottom:16px}
.contact-text{font-size:16px;color:var(--fg-muted);margin-bottom:28px;line-height:1.6}
.contact-meta{display:flex;flex-direction:column;gap:14px;margin-bottom:32px}
.contact-meta-item{display:flex;align-items:center;gap:12px;font-size:15px;color:var(--fg);font-weight:500}
.contact-deep{padding:24px;background:rgba(255,106,43,.05);border:1px solid rgba(255,106,43,.18);border-radius:14px;margin-top:24px}
.contact-deep h4{font-size:15px;font-weight:700;color:var(--heading);margin-bottom:6px}
.contact-deep p{font-size:14px;color:var(--fg-muted);margin-bottom:14px;line-height:1.55}
.contact-form-wrap{background:var(--surface-card);border:1px solid var(--border-ui);border-radius:28px;padding:36px;box-shadow:var(--shadow-md)}
.contact-form{display:flex;flex-direction:column;gap:20px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-group{display:flex;flex-direction:column;gap:6px;position:relative}
.form-full{grid-column:1/-1}
.form-group label{font-size:13px;font-weight:600;color:var(--heading);display:flex;align-items:center;gap:6px}
.form-opt{font-weight:400;color:var(--fg-muted)}
.form-required{color:var(--kowa-orange)}
.form-group input,.form-group select,.form-group textarea{font-family:inherit;font-size:15px;padding:12px 16px;border:1.5px solid var(--input-border);border-radius:8px;background:var(--surface-card);color:var(--fg);outline:none;width:100%;transition:.35s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--kowa-orange);box-shadow:0 0 0 3px rgba(255,106,43,.1)}
.form-group input.invalid,.form-group select.invalid,.form-group textarea.invalid{border-color:var(--error)}
.form-group input.invalid:focus,.form-group select.invalid:focus,.form-group textarea.invalid:focus{box-shadow:0 0 0 3px rgba(231,76,60,.1)}
.form-group textarea{min-height:120px;resize:vertical}
.form-error-msg{font-size:13px;color:var(--error);margin-top:2px}
.form-help{font-size:13px;color:var(--fg-muted);margin-top:2px;line-height:1.5}
.form-checkbox-row{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--fg);line-height:1.5}
.form-checkbox-row input{width:18px;height:18px;margin-top:2px;accent-color:var(--kowa-orange)}
.form-checkbox-row a{color:var(--kowa-orange);font-weight:500;border-bottom:1px solid rgba(255,106,43,.3)}

/* tooltip */
.tip{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:rgba(11,27,43,.06);color:var(--fg-muted);font-size:11px;font-weight:600;cursor:help;position:relative}
.tip:hover{background:rgba(255,106,43,.12);color:var(--kowa-orange)}
.tip::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--kowa-navy);color:#fff;font-size:12px;font-weight:500;padding:8px 12px;border-radius:8px;width:max-content;max-width:240px;line-height:1.45;opacity:0;visibility:hidden;transition:.2s;pointer-events:none;z-index:50;text-align:center;letter-spacing:0;text-transform:none;white-space:normal;box-shadow:0 8px 24px rgba(11,27,43,.18)}
.tip::before{content:'';position:absolute;bottom:calc(100% + 2px);left:50%;transform:translateX(-50%);border:6px solid transparent;border-top-color:var(--heading);opacity:0;visibility:hidden;transition:.2s;z-index:50}
.tip:hover::after,.tip:hover::before{opacity:1;visibility:visible}

/* spinner */
.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}
.btn-primary.done{background:#27ae60}

/* ---------- Briefing page (the heart) ---------- */
.briefing-page{position:relative;background:linear-gradient(180deg,#f7f8fa 0%,#fff 100%);min-height:100vh;padding:120px 0 80px}
.briefing-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.briefing-bg-orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.35}
.briefing-bg-orb-1{width:500px;height:500px;background:radial-gradient(circle,rgba(255,106,43,.16),transparent 70%);top:-10%;right:-10%}
.briefing-bg-orb-2{width:600px;height:600px;background:radial-gradient(circle,rgba(26,58,92,.12),transparent 70%);bottom:-20%;left:-15%}

.briefing-shell{position:relative;z-index:1;max-width:880px;margin:0 auto}
.briefing-intro{text-align:center;margin-bottom:36px}
.briefing-intro .section-tag{margin-bottom:14px}
.briefing-intro h1{font-size:clamp(34px,4.5vw,48px);font-weight:800;line-height:1.12;color:var(--heading);letter-spacing:-.03em;margin-bottom:16px}
.briefing-intro p{font-size:18px;color:var(--fg-muted);max-width:580px;margin:0 auto;line-height:1.55}
.briefing-meta-row{display:flex;justify-content:center;gap:28px;margin-top:24px;flex-wrap:wrap}
.briefing-meta-row span{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--fg-muted)}
.briefing-meta-row svg{color:var(--kowa-orange)}

/* progress */
.briefing-progress{margin:0 0 32px;background:var(--surface-card);border:1px solid rgba(11,27,43,.06);border-radius:18px;padding:20px 24px;box-shadow:0 4px 16px rgba(11,27,43,.04)}
.briefing-progress-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.briefing-progress-step{font-size:13px;color:var(--fg-muted);font-weight:500}
.briefing-progress-step strong{color:var(--heading);font-weight:700}
.briefing-progress-pct{font-size:13px;font-weight:700;color:var(--kowa-orange)}
.briefing-progress-bar{height:6px;background:rgba(11,27,43,.06);border-radius:3px;overflow:hidden;margin-bottom:14px}
.briefing-progress-fill{height:100%;background:linear-gradient(90deg,var(--kowa-orange),var(--kowa-orange-light));border-radius:3px;transition:width .55s cubic-bezier(.4,0,.2,1);box-shadow:0 0 12px rgba(255,106,43,.4)}
.briefing-progress-dots{display:flex;justify-content:space-between;gap:6px}
.briefing-progress-dot{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;min-width:0;cursor:default;transition:.2s}
.briefing-progress-dot[data-clickable="true"]{cursor:pointer}
.briefing-progress-dot[data-clickable="true"]:hover .briefing-progress-dot-circle{transform:scale(1.1)}
.briefing-progress-dot-circle{width:24px;height:24px;border-radius:50%;background:var(--surface-card);border:2px solid rgba(11,27,43,.12);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--fg-muted);transition:.3s}
.briefing-progress-dot.completed .briefing-progress-dot-circle{background:var(--kowa-orange);border-color:var(--kowa-orange);color:#fff}
.briefing-progress-dot.current .briefing-progress-dot-circle{background:var(--surface-card);border-color:var(--kowa-orange);color:var(--kowa-orange);box-shadow:0 0 0 4px rgba(255,106,43,.12)}
.briefing-progress-dot-label{font-size:11px;color:var(--fg-muted);text-align:center;line-height:1.3;font-weight:500;display:none}
@media (min-width:768px){.briefing-progress-dot-label{display:block}}
.briefing-progress-dot.current .briefing-progress-dot-label,.briefing-progress-dot.completed .briefing-progress-dot-label{color:var(--heading)}

/* card / step shell */
.briefing-card{background:var(--surface-card);border:1px solid rgba(11,27,43,.06);border-radius:24px;padding:48px;box-shadow:0 16px 64px rgba(11,27,43,.08);position:relative;overflow:hidden}
.briefing-step{animation:briefingSlide .55s cubic-bezier(.4,0,.2,1) both}
@keyframes briefingSlide{from{opacity:0;transform:translateX(28px)}to{opacity:1;transform:translateX(0)}}
.briefing-step.back{animation:briefingSlideBack .55s cubic-bezier(.4,0,.2,1) both}
@keyframes briefingSlideBack{from{opacity:0;transform:translateX(-28px)}to{opacity:1;transform:translateX(0)}}
.briefing-step-head{margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid rgba(11,27,43,.06)}
.briefing-step-eyebrow{font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--kowa-orange);margin-bottom:8px}
.briefing-step-head h2{font-size:28px;font-weight:800;color:var(--heading);letter-spacing:-.02em;line-height:1.18;margin-bottom:8px}
.briefing-step-head p{font-size:15px;color:var(--fg-muted);line-height:1.55}

.briefing-actions{display:flex;justify-content:space-between;align-items:center;margin-top:40px;padding-top:24px;border-top:1px solid rgba(11,27,43,.06);gap:16px}
.briefing-actions .btn-back{background:transparent;color:var(--fg-muted);padding:12px 18px;border:none;font-weight:500;font-size:14px;display:inline-flex;align-items:center;gap:6px;border-radius:8px;cursor:pointer;transition:.2s}
.briefing-actions .btn-back:hover{color:var(--heading);transform:translateX(-2px)}
.briefing-actions .btn-back:disabled{opacity:0;pointer-events:none}
.briefing-trust-line{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--fg-muted);margin-top:24px;justify-content:center}

/* service selection cards */
.briefing-cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.briefing-svc-card{position:relative;padding:28px;border:2px solid rgba(11,27,43,.08);border-radius:18px;background:var(--surface-card);cursor:pointer;transition:.3s cubic-bezier(.4,0,.2,1);text-align:left;display:flex;flex-direction:column;gap:14px}
.briefing-svc-card:hover{transform:translateY(-3px);border-color:rgba(255,106,43,.4);box-shadow:0 12px 40px rgba(11,27,43,.08)}
.briefing-svc-card.selected{border-color:var(--kowa-orange);background:linear-gradient(165deg,#fff,rgba(255,106,43,.04));box-shadow:0 8px 32px rgba(255,106,43,.18)}
.briefing-svc-card-icon{width:48px;height:48px}
.briefing-svc-card h3{font-size:18px;font-weight:700;color:var(--heading)}
.briefing-svc-card p{font-size:14px;color:var(--fg-muted);line-height:1.5}
.briefing-svc-card-check{position:absolute;top:14px;right:14px;width:24px;height:24px;border-radius:50%;background:var(--kowa-orange);color:#fff;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.6);transition:.3s}
.briefing-svc-card.selected .briefing-svc-card-check{opacity:1;transform:scale(1)}

/* radio cards (2-up) */
.briefing-radio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}
.briefing-radio-grid--2{grid-template-columns:repeat(2,1fr)}
.briefing-radio-card{padding:14px 16px;border:1.5px solid rgba(11,27,43,.1);border-radius:10px;background:var(--surface-card);cursor:pointer;font-size:14px;font-weight:500;color:var(--fg);text-align:center;transition:.25s}
.briefing-radio-card:hover{border-color:rgba(255,106,43,.4);color:var(--heading)}
.briefing-radio-card.selected{border-color:var(--kowa-orange);background:rgba(255,106,43,.06);color:var(--heading);font-weight:600;box-shadow:0 0 0 3px rgba(255,106,43,.08)}

/* budget slider */
.briefing-budget{padding:24px;background:var(--bg-alt);border-radius:16px;border:1px solid var(--border-ui)}
.briefing-budget-display{text-align:center;margin-bottom:20px}
.briefing-budget-val{font-size:32px;font-weight:800;color:var(--kowa-orange);letter-spacing:-.02em;line-height:1}
.briefing-budget-lbl{font-size:13px;color:var(--fg-muted);margin-top:6px;text-transform:uppercase;letter-spacing:1px;font-weight:500}
.briefing-budget-slider{position:relative;padding:0 6px}
.briefing-budget-slider input[type=range]{width:100%;height:6px;-webkit-appearance:none;appearance:none;background:rgba(11,27,43,.1);border-radius:3px;outline:none}
.briefing-budget-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;background:var(--kowa-orange);border-radius:50%;cursor:pointer;border:3px solid #fff;box-shadow:0 4px 12px rgba(255,106,43,.4);transition:.2s}
.briefing-budget-slider input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}
.briefing-budget-slider input[type=range]::-moz-range-thumb{width:18px;height:18px;background:var(--kowa-orange);border-radius:50%;cursor:pointer;border:3px solid #fff;box-shadow:0 4px 12px rgba(255,106,43,.4)}
.briefing-budget-ticks{display:flex;justify-content:space-between;margin-top:12px;font-size:11px;color:var(--fg-muted);font-weight:500}

/* dropzone */
.briefing-drop{padding:32px 24px;border:2px dashed var(--border-ui-strong);border-radius:14px;background:var(--bg-alt);text-align:center;cursor:pointer;transition:.3s}
.briefing-drop:hover,.briefing-drop.dragover{border-color:var(--kowa-orange);background:rgba(255,106,43,.04)}
.briefing-drop-icon{width:48px;height:48px;border-radius:12px;background:rgba(255,106,43,.08);margin:0 auto 12px;display:flex;align-items:center;justify-content:center}
.briefing-drop p{font-size:15px;color:var(--fg);font-weight:500;margin-bottom:4px}
.briefing-drop span{font-size:13px;color:var(--fg-muted)}
.briefing-drop input{display:none}
.briefing-files{display:flex;flex-direction:column;gap:8px;margin-top:14px}
.briefing-file{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--surface-card);border:1px solid rgba(11,27,43,.06);border-radius:10px;font-size:13px}
.briefing-file-icon{width:28px;height:28px;border-radius:6px;background:rgba(255,106,43,.08);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--kowa-orange);font-weight:700;font-size:11px}
.briefing-file-name{flex:1;color:var(--fg);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.briefing-file-size{color:var(--fg-muted);font-size:12px}
.briefing-file-x{width:24px;height:24px;border-radius:50%;background:transparent;border:none;cursor:pointer;color:var(--fg-muted);display:flex;align-items:center;justify-content:center;transition:.2s}
.briefing-file-x:hover{background:rgba(231,76,60,.1);color:var(--error)}

/* generic field group inside briefing */
.briefing-field{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.briefing-field--row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.briefing-field--row .briefing-field{margin-bottom:0}
.briefing-field label{font-size:13px;font-weight:600;color:var(--heading);display:flex;align-items:center;gap:6px}
.briefing-field input,.briefing-field select,.briefing-field textarea{font-family:inherit;font-size:15px;padding:12px 16px;border:1.5px solid var(--input-border);border-radius:8px;background:var(--surface-card);color:var(--fg);outline:none;width:100%;transition:.25s}
.briefing-field input:focus,.briefing-field select:focus,.briefing-field textarea:focus{border-color:var(--kowa-orange);box-shadow:0 0 0 3px rgba(255,106,43,.1)}
.briefing-field input.invalid,.briefing-field select.invalid,.briefing-field textarea.invalid{border-color:var(--error)}
.briefing-field textarea{min-height:100px;resize:vertical}
.briefing-field-hint{font-size:12px;color:var(--fg-muted);margin-top:2px;line-height:1.5}
.briefing-field-error{font-size:12px;color:var(--error);margin-top:2px}

.briefing-section-block{margin-bottom:24px}
.briefing-section-block:last-child{margin-bottom:0}
.briefing-section-block h3{font-size:14px;font-weight:700;color:var(--heading);text-transform:uppercase;letter-spacing:1px;margin-bottom:14px}

/* Success page */
.briefing-success{text-align:center;max-width:680px;margin:0 auto;padding:60px 40px}
.briefing-success-circle{width:104px;height:104px;border-radius:50%;background:linear-gradient(135deg,#28c840,#1ea832);margin:0 auto 28px;display:flex;align-items:center;justify-content:center;color:#fff;animation:successPop .65s cubic-bezier(.5,1.6,.4,1) both;box-shadow:0 12px 40px rgba(40,200,64,.3)}
.briefing-success-circle::before{content:'';position:absolute;width:140px;height:140px;border-radius:50%;border:2px solid rgba(40,200,64,.4);animation:successRing 2s ease-out infinite}
@keyframes successPop{0%{transform:scale(0)}65%{transform:scale(1.12)}100%{transform:scale(1)}}
@keyframes successRing{0%{transform:scale(.85);opacity:1}100%{transform:scale(1.4);opacity:0}}
.briefing-success h1{font-size:clamp(30px,4vw,42px);font-weight:800;color:var(--heading);letter-spacing:-.02em;margin-bottom:14px}
.briefing-success-lead{font-size:18px;color:var(--fg-muted);line-height:1.5;margin-bottom:32px}
.briefing-success-meta{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:rgba(255,106,43,.08);border:1px solid rgba(255,106,43,.18);color:var(--kowa-orange);border-radius:999px;font-size:14px;font-weight:600;margin-bottom:32px}
.briefing-summary{background:var(--bg-alt);border:1px solid rgba(11,27,43,.06);border-radius:16px;padding:28px;text-align:left;margin-bottom:28px}
.briefing-summary h3{font-size:15px;font-weight:700;color:var(--heading);text-transform:uppercase;letter-spacing:1px;margin-bottom:14px}
.briefing-summary-row{display:grid;grid-template-columns:160px 1fr;padding:10px 0;border-bottom:1px solid rgba(11,27,43,.05);gap:18px}
.briefing-summary-row:last-child{border-bottom:none}
.briefing-summary-key{font-size:13px;color:var(--fg-muted);font-weight:500}
.briefing-summary-val{font-size:14px;color:var(--fg);font-weight:500;word-break:break-word}
.briefing-success-actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}

/* Trust strip */
.trust-strip{padding:32px 0;background:var(--bg-alt);border-top:1px solid rgba(11,27,43,.06);border-bottom:1px solid rgba(11,27,43,.06)}
.trust-strip-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;text-align:center}
.trust-strip-item{display:flex;flex-direction:column;align-items:center;gap:8px}
.trust-strip-icon{width:36px;height:36px;border-radius:10px;background:rgba(255,106,43,.08);display:flex;align-items:center;justify-content:center}
.trust-strip-text{font-size:13px;color:var(--fg-muted);font-weight:500;line-height:1.4}
.trust-strip-text strong{color:var(--heading);font-weight:700;display:block;font-size:14px}

/* Legal page styles */
.legal-page{max-width:760px;margin:0 auto;padding:140px 24px 80px}
.legal-page h1{font-size:clamp(30px,4vw,42px);font-weight:800;color:var(--heading);letter-spacing:-.02em;margin-bottom:14px}
.legal-page .legal-meta{font-size:14px;color:var(--fg-muted);margin-bottom:36px;padding-bottom:20px;border-bottom:1px solid rgba(11,27,43,.06)}
.legal-download{display:flex;flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:36px}
.legal-download-hint{font-size:13px;color:var(--fg-muted);line-height:1.5}
.legal-page a:not(.btn){color:var(--kowa-orange);text-decoration:underline;text-underline-offset:3px}
.legal-page h2{font-size:20px;font-weight:700;color:var(--heading);margin-top:32px;margin-bottom:12px;letter-spacing:-.01em}
.legal-page h3{font-size:16px;font-weight:700;color:var(--heading);margin-top:18px;margin-bottom:8px}
.legal-page p,.legal-page li{font-size:15px;color:var(--fg);line-height:1.7;margin-bottom:10px}
.legal-page ul{padding-left:22px;list-style:disc;margin-bottom:16px}
.legal-page strong{color:var(--heading);font-weight:600}
.legal-placeholder-banner{padding:18px 22px;background:rgba(254,188,46,.08);border:1px solid rgba(254,188,46,.3);border-radius:12px;font-size:14px;color:var(--fg);margin-bottom:32px;display:flex;gap:12px;align-items:flex-start;line-height:1.55}
.legal-placeholder-banner svg{flex-shrink:0;color:#c89400;margin-top:2px}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .hero-inner,.about-grid,.contact-grid,.svc-hero-inner,.svc-two,.svc-cta-banner-inner,.product-showcase-grid{grid-template-columns:1fr;gap:48px}
  .services-grid,.results-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .svc-cta-banner-actions{align-items:flex-start}
  .trust-strip-grid{grid-template-columns:repeat(2,1fr);gap:24px}
}
@media (max-width:768px){
  /* Base */
  .section{padding:64px 0}
  .container{padding:0 18px}

  /* Nav */
  .nav{padding:10px 0}
  .nav.scrolled{padding:8px 0}
  .nav-links{display:none}
  .nav-toggle{display:flex;width:44px;height:44px}
  .nav-logo-icon{padding:6px 14px}
  .nav-logo-icon img{height:44px;width:auto}
  .nav.mobile-open .nav-mobile{display:flex;flex-direction:column;background:var(--surface-card);position:absolute;top:100%;left:0;right:0;padding:24px 20px;box-shadow:var(--shadow-lg);gap:4px;border-top:1px solid var(--border-ui)}
  .nav-mobile-theme{display:flex}
  .nav.mobile-open .nav-mobile a{font-size:17px;font-weight:500;color:var(--heading);padding:12px 0;border-bottom:1px solid var(--border-ui)}
  .nav.mobile-open .nav-mobile a:last-child{border-bottom:none}
  .nav.mobile-open .nav-mobile .btn{width:100%;justify-content:center;margin-top:10px;padding:15px;font-size:15px}
  .nav-cta-row .btn-nav-ghost{display:none}

  /* Hero */
  .hero{padding:100px 0 56px;min-height:auto}
  .hero-inner{gap:32px}
  .hero-eyebrow{margin-bottom:14px}
  .hero-title{font-size:clamp(28px,8.5vw,40px);margin-bottom:14px}
  .hero-subtitle{font-size:16px;margin-bottom:22px;line-height:1.55}
  .hero-ctas{flex-direction:column;gap:10px;margin-bottom:20px}
  .hero-ctas .btn{flex:none;width:100%;min-width:0;font-size:15px;padding:16px 20px;border-radius:10px}
  .hero-trust{font-size:13px}
  .hero-terminal{width:100%;max-width:100%;border-radius:14px}
  .hero-terminal-glass{border-radius:14px}
  .terminal-screen{padding:16px 16px 20px;font-size:12.5px;min-height:160px}
  .hero-float{display:none}
  .hero-orb-1,.hero-orb-2,.hero-orb-3{opacity:.3}

  /* Section headings */
  .section-head{margin-bottom:36px}
  .section-title{font-size:clamp(24px,7vw,34px);margin-bottom:12px}
  .section-desc{font-size:15px;max-width:100%}
  .section-tag{font-size:12px}

  /* Services */
  .services-grid,.results-grid,.briefing-cards-grid,.svc-features{grid-template-columns:1fr}
  .svc-card-body{padding:24px 20px}
  .svc-icon{width:52px;height:52px;margin-bottom:16px}
  .svc-card h3{font-size:19px}

  /* About */
  .about-grid{gap:32px}
  .about-portrait{width:200px;margin:0 auto}
  .about-stat{padding:8px 14px}
  .about-stat-val{font-size:18px}
  .about-stat-1{top:-8px;right:-8px}
  .about-stat-2{bottom:50px;left:-10px}
  .about-stat-3{bottom:-8px;right:0}
  .about-text{font-size:16px;margin-bottom:24px}

  /* Process */
  .process-timeline{padding-left:4px}
  .process-step{gap:16px}
  .process-marker{width:44px;height:44px;min-width:44px}
  .process-marker span{font-size:14px}
  .process-body h3{font-size:18px}
  .process-steps{gap:36px}

  /* Results */
  .res-card-inner{padding:24px 20px}
  .res-metric-num,.res-metric-text{font-size:38px}

  /* Trust strip */
  .trust-strip{padding:24px 0}
  .trust-strip-grid{grid-template-columns:1fr 1fr;gap:16px}
  .trust-strip-text strong{font-size:13px}
  .trust-strip-text{font-size:12px}

  /* FAQ */
  .faq-question{font-size:15px;padding:16px 0}
  .faq-answer{font-size:15px}

  /* Sticky CTA */
  .sticky-cta{bottom:16px;right:16px;padding:12px 18px;font-size:13px}

  /* Footer */
  .footer{padding:44px 0 24px}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-brand-block{max-width:100%}
  .footer-brand-row img{height:48px}
  .footer-bar{flex-direction:column;align-items:flex-start;gap:8px;padding-top:20px}
  .footer-bar-legal{gap:16px;flex-wrap:wrap}
  .footer-bar-meta{font-size:12px}

  /* Contact */
  .contact-form-wrap{padding:24px 18px;border-radius:18px}
  .form-row{grid-template-columns:1fr}

  /* Pages */
  .page-hero,.svc-hero{padding:110px 0 48px}
  .page-hero h1{font-size:clamp(28px,7vw,40px)}
  .page-hero p{font-size:17px}
  .svc-cta-banner-actions{align-items:stretch}
  .svc-cta-banner-actions .btn{width:100%;justify-content:center}

  /* Briefing */
  .briefing-page{padding:96px 0 60px}
  .briefing-card{padding:24px 18px;border-radius:18px}
  .briefing-step-head h2{font-size:21px}
  .briefing-success{padding:28px 16px}
  .briefing-summary-row{grid-template-columns:1fr;gap:2px}
  .briefing-field--row{grid-template-columns:1fr;gap:0}
  .briefing-field--row .briefing-field{margin-bottom:18px}
  .briefing-progress-dots .briefing-progress-dot:nth-child(odd) .briefing-progress-dot-circle{display:flex}

  /* Legal */
  .legal-page{padding:110px 16px 60px}
}

/* Extra small screens */
@media (max-width:400px){
  .hero-title{font-size:28px}
  .hero-subtitle{font-size:15px}
  .btn-lg,.btn-full{font-size:15px;padding:15px 20px}
  .briefing-intro h1{font-size:28px}
  .section-title{font-size:26px}
  .nav-brand{font-size:17px}
  .nav-sub{font-size:11px}
  .hero-ctas .btn{padding:15px 20px}
}

/* ---------- HandwerkOS / product showcase ---------- */
.product-showcase{background:var(--kowa-navy);color:var(--fg-inv);overflow:hidden}
.product-showcase .section-tag{color:var(--kowa-orange-light)}
.product-showcase .section-title{color:#fff}
.product-showcase-title{text-align:left;margin-left:0}
.product-showcase-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:56px;align-items:center}
.product-showcase-lead{font-size:17px;line-height:1.65;color:var(--fg-inv);opacity:.85;margin-bottom:28px;max-width:520px}
.product-showcase-list{list-style:none;display:flex;flex-direction:column;gap:16px;margin-bottom:32px}
.product-showcase-list li{display:flex;gap:14px;align-items:flex-start}
.product-showcase-list-icon{width:28px;height:28px;min-width:28px;border-radius:8px;background:rgba(255,106,43,.15);display:flex;align-items:center;justify-content:center;margin-top:2px}
.product-showcase-list li strong{display:block;font-size:15px;font-weight:600;color:#fff;margin-bottom:2px}
.product-showcase-list li span{font-size:14px;color:var(--fg-inv);opacity:.72;line-height:1.5}
.product-showcase-actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}
.product-showcase-meta{font-size:13px;color:var(--fg-inv);opacity:.55}
.product-showcase-card{
  background:linear-gradient(165deg,rgba(26,58,92,.55),rgba(11,27,43,.92));
  border:1px solid rgba(255,255,255,.08);
  border-radius:24px;padding:28px 26px;
  box-shadow:0 24px 64px rgba(0,0,0,.35);
}
.product-showcase-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.product-showcase-logo{font-size:22px;font-weight:800;color:#fff;letter-spacing:-.02em}
.product-showcase-pill{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;padding:4px 10px;border-radius:999px;background:rgba(255,106,43,.2);color:var(--kowa-orange-light)}
.product-showcase-tagline{font-size:15px;color:var(--fg-inv);opacity:.75;margin-bottom:20px}
.product-showcase-inbox{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.product-showcase-ticket{padding:12px 14px;border-radius:12px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06)}
.product-showcase-ticket--urgent{border-color:rgba(255,106,43,.35);background:rgba(255,106,43,.1)}
.product-showcase-ticket-badge{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--kowa-orange-light);margin-bottom:4px}
.product-showcase-ticket strong{display:block;font-size:14px;color:#fff;margin-bottom:2px}
.product-showcase-ticket span{font-size:12px;color:var(--fg-inv);opacity:.65}
.product-showcase-card-foot{font-size:12px;color:var(--fg-inv);opacity:.55;text-align:center}
.product-page-panel{padding:28px;background:var(--surface-card);border:1px solid var(--border-ui);border-radius:20px;box-shadow:var(--shadow-md)}
.product-page-panel h3{font-size:18px;font-weight:700;color:var(--heading);margin-bottom:16px}
.product-page-pricing{list-style:none;margin-bottom:20px}
.product-page-pricing li{display:flex;justify-content:space-between;gap:16px;padding:10px 0;border-bottom:1px solid var(--border-ui);font-size:14px}
.product-page-pricing li:last-child{border-bottom:none}
.product-page-pricing span{color:var(--fg-muted)}
.product-page-pricing strong{color:var(--heading);font-weight:600}
.product-page-cta-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}
[data-theme="dark"] .product-showcase-card{border-color:rgba(255,255,255,.1)}
[data-theme="dark"] .product-page-panel{background:var(--surface-card)}

/* ---------- Theme toggle ---------- */
.theme-toggle{position:relative;display:inline-flex;align-items:center;justify-content:center;width:52px;height:30px;padding:0;border:none;background:transparent;cursor:pointer;flex-shrink:0}
.theme-toggle-track{display:block;width:52px;height:30px;border-radius:999px;background:var(--bg-alt);border:1.5px solid var(--border-ui-strong);transition:.35s cubic-bezier(.4,0,.2,1)}
.theme-toggle-thumb{position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:var(--kowa-orange);box-shadow:0 2px 8px rgba(255,106,43,.35);transition:transform .35s cubic-bezier(.4,0,.2,1)}
.theme-toggle-thumb.is-dark{transform:translateX(22px)}
.theme-toggle-icons{position:absolute;inset:0;display:flex;align-items:center;justify-content:space-between;padding:0 9px;pointer-events:none;color:var(--fg-muted)}
.theme-toggle-icons svg{width:14px;height:14px;opacity:.55}
.nav-cta-row .theme-toggle{margin-right:2px}
.nav-mobile-theme{display:none;align-items:center;justify-content:space-between;padding:12px 0 16px;margin-bottom:8px;border-bottom:1px solid var(--border-ui)}
.nav-mobile-theme span{font-size:14px;font-weight:600;color:var(--heading)}

/* Smooth fade-in for page transitions */
.page-fade{animation:pageFade .45s cubic-bezier(.4,0,.2,1) both}
@keyframes pageFade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
