/* ============================================
   Patter — Landing Page
   Aesthetic: Manufact-inspired editorial minimal
   ============================================ */

/* Fonts loaded via <link> in HTML head for faster rendering */

/* --- Tokens --- */
:root {
  --bg: #fdfcfc;
  --fg: #09090b;
  --card: #ffffff;
  --primary: #18181b;
  --primary-fg: #fafafa;
  --secondary: #f4f4f5;
  --muted: #71717b;
  --border: #e4e4e7;
  --border-d: #d4d4d8;
  --green: #22c55e;
  --red: #ef4444;
  --blue: #3b82f6;
  --purple: #a78bfa;
  --orange: #fb923c;
  --radius: 12px;
  --font: 'Instrument Sans', ui-sans-serif, system-ui, sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
}

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--font);font-size:16px;line-height:1.6;color:var(--fg);background:var(--bg);overflow-x:hidden}
/* Subtle page-wide dotted texture */
/* Grain pattern only inside hero — see .hero-grain */
a{color:inherit;text-decoration:none}
ul{list-style:none}
img{max-width:100%;display:block}

.container{max-width:1400px;margin:0 auto;padding:0 24px}

/* --- Buttons (pill + arrow) --- */
.btn-primary,.btn-ghost{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font);font-weight:600;border-radius:100px;
  cursor:pointer;transition:all .2s;text-decoration:none;white-space:nowrap;
}
.btn-primary{background:var(--primary);color:var(--primary-fg);border:1px solid var(--primary)}
.btn-primary:hover{opacity:.9}
.btn-ghost{background:var(--card);color:var(--fg);border:1px solid var(--border)}
.btn-ghost:hover{background:var(--secondary)}
.btn-sm{padding:8px 18px;font-size:13px}
.btn-md{padding:10px 24px;font-size:14px}
.btn-lg{padding:13px 30px;font-size:15px}
.arrow{transition:transform .2s}
.btn-primary:hover .arrow,.btn-ghost:hover .arrow{transform:translateX(3px)}

/* --- Cookie --- */
.cookie-banner{position:fixed;bottom:24px;left:24px;max-width:420px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;display:flex;flex-direction:column;gap:12px;z-index:1000;box-shadow:0 8px 32px rgba(0,0,0,.08);animation:slideUp .4s ease}
.cookie-banner.hidden{display:none}
.cookie-banner p{font-size:13px;color:var(--muted)}
.cookie-banner a{text-decoration:underline}
.cookie-actions{display:flex;gap:8px}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}

/* --- Header --- */
.header{position:fixed;top:0;left:0;right:0;z-index:10000;background:#fff;border-bottom:1px solid rgba(228,228,231,.5)}
.header::before{content:"";position:absolute;top:-100px;left:0;right:0;height:100px;background:#fff}
.header-inner{max-width:1400px;margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;justify-content:space-between;position:relative}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:22px;letter-spacing:-.02em}
.logo-icon{width:auto;height:28px;display:block}
.nav-desktop{position:absolute;left:50%;transform:translateX(-50%)}
.nav-desktop ul{display:flex;gap:28px}
.nav-desktop a{font-size:14px;font-weight:500;color:var(--muted);transition:color .2s}
.nav-desktop a:hover{color:var(--fg)}
.header-actions{display:flex;align-items:center;gap:10px}
.github-badge{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border:1px solid var(--border);border-radius:100px;font-size:13px;font-weight:500;color:var(--muted);transition:all .2s}
.github-badge:hover{background:var(--secondary);color:var(--fg)}
.github-badge svg{width:16px;height:16px}
/* Desktop dropdown */
.nav-dropdown{position:relative}
.nav-dropdown-trigger{background:none;border:none;font-size:14px;font-weight:500;color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;gap:4px;padding:0;font-family:inherit;transition:color .2s}
.nav-dropdown-trigger:hover{color:var(--fg)}
.nav-dropdown-trigger svg{transition:transform .2s}
.nav-dropdown-menu{position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(4px);background:#fff;border:1px solid var(--border);border-radius:12px;padding:6px;min-width:200px;box-shadow:0 8px 24px rgba(0,0,0,.08);opacity:0;pointer-events:none;transition:opacity .2s,transform .2s}
.nav-dropdown-menu::before{content:"";position:absolute;top:-16px;left:0;right:0;height:16px}
.nav-dropdown:hover .nav-dropdown-menu{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.nav-dropdown:hover .nav-dropdown-trigger{color:var(--fg)}
.nav-dropdown:hover .nav-dropdown-trigger svg{transform:rotate(180deg)}
.nav-dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:8px;font-size:13px;font-weight:500;color:var(--fg);transition:background .15s}
.nav-dropdown-item:hover{background:var(--secondary)}
.nav-dropdown-disabled{cursor:default}
.nav-dropdown-disabled:hover{background:transparent}
.nav-dropdown-item img{opacity:.6}
.nav-badge{font-size:10px;font-weight:600;color:#f97316;background:rgba(249,115,22,.08);padding:2px 6px;border-radius:4px;margin-left:auto}
/* Mobile accordion */
.mobile-accordion-trigger{background:none;border:none;font-size:15px;color:var(--muted);cursor:pointer;display:flex;align-items:center;gap:6px;padding:12px 0;min-height:44px;font-family:inherit;font-weight:500;width:100%}
.mobile-accordion-trigger svg{transition:transform .2s;margin-left:2px}
.mobile-accordion.open .mobile-accordion-trigger svg{transform:rotate(180deg)}
.mobile-accordion-content{display:none;padding:0 0 8px 8px;flex-direction:column;gap:2px}
.mobile-accordion.open .mobile-accordion-content{display:flex}
.mobile-accordion-content a{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:8px;font-size:14px;color:var(--fg);transition:background .15s}
.mobile-accordion-content a:hover{background:var(--secondary)}
.mobile-accordion-content img{opacity:.5}
.mobile-menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.mobile-menu-toggle span{display:block;width:20px;height:2px;background:var(--fg);border-radius:2px;transition:all .3s}
.mobile-nav{position:fixed;top:48px;left:0;right:0;width:100%;background:#fff;border-bottom:1px solid var(--border);padding:16px 24px;z-index:10000;box-shadow:0 8px 24px rgba(0,0,0,.08);transform:translateY(-100%);opacity:0;pointer-events:none;transition:transform .25s ease,opacity .25s ease}
.mobile-nav.open{transform:translateY(0);opacity:1;pointer-events:auto}
.mobile-nav ul{display:flex;flex-direction:column;gap:4px}
.mobile-nav a{font-size:15px;color:var(--muted);min-height:44px;display:flex;align-items:center;padding:12px 0}
.mobile-nav .github-badge{justify-content:center}
.mobile-nav .btn-primary{justify-content:center}
.mobile-nav li:last-child,.mobile-nav li:nth-last-child(2){display:inline-block}
.mobile-nav ul{gap:8px}
.mobile-nav .github-badge,.mobile-nav .btn-primary{font-size:13px;padding:8px 16px;min-height:40px}

/* --- Page Rails (vertical lines removed, padding kept) --- */
.page-rails{
  position:relative;
  padding:0 20px;
}
@media(min-width:1249px){
  .page-rails{padding:0 calc(50% - 720px)}
}

/* --- Hero --- */
.hero{position:relative;padding:160px 0 100px;text-align:center;overflow:hidden;margin:0;display:flex;align-items:center;justify-content:center;
  border-left:1px solid var(--border);border-right:1px solid var(--border);border-bottom:1px solid var(--border);
}
/* Hero bottom corner dots — placed on the first section after hero instead,
   because hero has overflow:hidden which clips children */
.hero-dot-bl,.hero-dot-br{display:none}
.hero + .section-panel{position:relative}
.hero + .section-panel .corner-dot-tl,
.hero + .section-panel .corner-dot-tr{
  position:absolute;width:7px;height:7px;border-radius:50%;background:var(--border-d);z-index:10;display:block;
}
.hero + .section-panel .corner-dot-tl{top:-4px;left:-1px}
.hero + .section-panel .corner-dot-tr{top:-4px;right:-1px}
/* Color blobs — pastel, vivid but light */
.hero-bg-base{position:absolute;top:-10%;left:-10%;right:-10%;bottom:-10%;z-index:0;filter:blur(60px);background:
  radial-gradient(ellipse 100% 80% at 50% 100%,rgba(237,241,188,.65) 0%,transparent 60%),
  radial-gradient(ellipse 80% 100% at 0% 50%,rgba(160,190,245,.55) 0%,transparent 50%),
  radial-gradient(ellipse 80% 100% at 100% 50%,rgba(200,205,215,.5) 0%,transparent 50%)}
.hero::before,.hero::after,.hero-blob-a,.hero-blob-b,.hero-blob-c{content:"";position:absolute;top:-30%;left:-30%;right:-30%;bottom:-30%;z-index:0;filter:blur(80px)}
.hero::before{background:radial-gradient(circle 60vw at 50% 50%,rgba(90,150,240,.6) 0%,rgba(90,150,240,.18) 40%,transparent 70%);
  animation:heroDrift1 24s ease-in-out infinite}
.hero::after{background:radial-gradient(circle 55vw at 50% 50%,rgba(237,241,188,.7) 0%,rgba(237,241,188,.2) 40%,transparent 70%);
  animation:heroDrift2 30s ease-in-out infinite}
.hero-blob-a{background:radial-gradient(circle 58vw at 50% 50%,rgba(170,185,210,.6) 0%,rgba(170,185,210,.18) 40%,transparent 70%);
  animation:heroDrift3 27s ease-in-out infinite}
.hero-blob-b{background:radial-gradient(circle 50vw at 50% 50%,rgba(248,200,160,.55) 0%,rgba(248,200,160,.14) 40%,transparent 70%);
  animation:heroDrift4 22s ease-in-out infinite}
.hero-blob-c{background:radial-gradient(circle 48vw at 50% 50%,rgba(180,225,180,.5) 0%,rgba(180,225,180,.12) 40%,transparent 70%);
  animation:heroDrift5 26s ease-in-out infinite}
/* White overlay on top — fades out toward edges */
.hero-white-overlay{position:absolute;top:0;left:0;right:0;bottom:0;z-index:1;pointer-events:none;background:
  radial-gradient(ellipse 80% 85% at 50% 35%,rgba(253,252,252,1) 0%,rgba(253,252,252,1) 35%,rgba(253,252,252,.9) 50%,rgba(253,252,252,.5) 70%,rgba(253,252,252,0) 100%),
  linear-gradient(to bottom,rgba(253,252,252,1) 0%,rgba(253,252,252,.6) 15%,rgba(253,252,252,0) 35%)}
@keyframes heroDrift1{
  0%{transform:translate(-35%,30%)}
  18%{transform:translate(25%,20%)}
  40%{transform:translate(30%,-15%)}
  58%{transform:translate(-10%,-25%)}
  76%{transform:translate(-30%,5%)}
  100%{transform:translate(-35%,30%)}
}
@keyframes heroDrift2{
  0%{transform:translate(30%,-20%)}
  22%{transform:translate(-20%,-30%)}
  45%{transform:translate(-35%,15%)}
  65%{transform:translate(5%,30%)}
  85%{transform:translate(35%,5%)}
  100%{transform:translate(30%,-20%)}
}
@keyframes heroDrift3{
  0%{transform:translate(0%,35%)}
  15%{transform:translate(30%,10%)}
  33%{transform:translate(15%,-30%)}
  52%{transform:translate(-25%,-15%)}
  70%{transform:translate(-30%,20%)}
  88%{transform:translate(-5%,35%)}
  100%{transform:translate(0%,35%)}
}
@keyframes heroDrift4{
  0%{transform:translate(25%,-25%)}
  20%{transform:translate(-15%,-10%)}
  42%{transform:translate(-30%,25%)}
  60%{transform:translate(10%,30%)}
  80%{transform:translate(30%,0%)}
  100%{transform:translate(25%,-25%)}
}
@keyframes heroDrift5{
  0%{transform:translate(-20%,-20%)}
  18%{transform:translate(20%,-30%)}
  38%{transform:translate(30%,10%)}
  55%{transform:translate(0%,30%)}
  72%{transform:translate(-25%,15%)}
  90%{transform:translate(-30%,-10%)}
  100%{transform:translate(-20%,-20%)}
}
/* Dotted grain texture overlay */
.hero-grain{position:absolute;top:0;left:0;right:0;bottom:0;z-index:0;pointer-events:none;opacity:.35;mix-blend-mode:multiply;background:url('grain.jpg') repeat;background-size:400px}
.hero .container{position:relative;z-index:2;width:100%}
.hero-card{padding:100px 80px 76px;max-width:1160px;margin:0 auto;position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:5px 14px;background:rgba(255,255,255,.9);border:1px solid var(--border);border-radius:100px;font-size:12px;margin-bottom:24px}
.badge-label{font-weight:700;color:var(--fg)}
.badge-text{color:var(--muted)}
.hero-title{font-size:clamp(46px,7vw,80px);font-weight:700;line-height:1.05;letter-spacing:-.035em;margin-bottom:24px;max-width:850px;margin-left:auto;margin-right:auto}
.hero-subtitle{font-size:21px;color:var(--muted);font-weight:500;max-width:600px;margin:0 auto 40px;line-height:1.65}
.hero-subtitle a{text-decoration:underline;text-underline-offset:3px}
.hero-cta{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:28px}
.hero-cta .btn-primary,.hero-cta .btn-ghost{min-width:180px}
.hero-oss{font-size:12px;color:var(--muted);margin-bottom:14px;text-transform:uppercase;letter-spacing:.1em;font-weight:600}
.install-commands{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}
.install-cmd{display:inline-flex;align-items:center;gap:10px;padding:8px 14px;background:var(--card);border:1px solid var(--border);border-radius:10px;font-family:var(--mono);font-size:12.5px;color:var(--fg)}
.install-cmd .cmd-icon{font-size:15px;line-height:1}
.cmd-icon-img{display:block;flex-shrink:0}
.copy-btn{background:none;border:none;cursor:pointer;color:var(--muted);padding:2px;transition:color .2s;display:flex;align-items:center}
.copy-btn:hover{color:var(--fg)}

/* --- Logo Cloud --- */
.logo-cloud{padding:32px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden;margin:0}
.logo-track{overflow:hidden;mask-image:linear-gradient(to right,transparent,black 8%,black 92%,transparent);-webkit-mask-image:linear-gradient(to right,transparent,black 8%,black 92%,transparent)}
.logo-slide{display:flex;align-items:center;gap:56px;animation:marquee 30s linear infinite;width:max-content}
.partner-logo{font-size:18px;font-weight:700;color:var(--fg);opacity:.2;white-space:nowrap;letter-spacing:-.01em}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-33.333%)}}

/* ============================
   SECTION SYSTEM (Manufact-style bordered panels with corner dots)
   ============================ */
.section-panel{
  position:relative;
  z-index:2;
  background:transparent;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  border-left:none;
  border-right:none;
  border-radius:0;
  margin:0;
  padding:72px 0;
  overflow:visible;
}
/* Stacked sections: collapse shared border, hide duplicate top dots */
.section-panel + .section-panel{
  border-top:none;
  margin-top:-1px;
}
.section-panel + .section-panel::before,
.section-panel + .section-panel::after{
  display:none;
}
/* First section after hero — hide top border against gradient */
.hero + .section-panel{
  border-top-color:transparent;
}

/* Corner dots removed — only horizontal borders remain */
.section-panel::before,.section-panel::after{display:none}
.section-panel .corner-bl,.section-panel .corner-br{display:none}

/* --- Section Labels (pill badge) --- */
.section-label{
  display:inline-block;font-size:11px;font-weight:600;color:var(--muted);
  text-transform:uppercase;letter-spacing:.1em;
  margin-bottom:14px;padding:4px 14px;
  border:1px solid var(--border);border-radius:100px;
  font-family:var(--mono);
}
.section-title{font-size:clamp(26px,3.5vw,42px);font-weight:700;line-height:1.1;letter-spacing:-.03em;margin-bottom:14px}
.section-subtitle{font-size:18px;color:var(--muted);max-width:600px;line-height:1.65;font-weight:500}
.section-center{text-align:center}
.section-center .section-subtitle{margin:0 auto}

/* --- Code Comparison --- */
.code-compare{padding:48px 0 72px}
.code-compare .section-subtitle{margin:0 auto 72px}
.code-compare .section-two-col{margin-top:40px}
.code-panels{display:grid;grid-template-columns:1fr 1fr;gap:16px;text-align:left;margin-top:0;align-items:stretch}

/* --- Code Panel (macOS window chrome) --- */
.code-panel{
  border:1px solid var(--border);border-radius:18px;overflow:hidden;background:var(--card);
  box-shadow:0 12px 40px rgba(0,0,0,.1),0 4px 12px rgba(0,0,0,.05);
  transition:box-shadow .3s,transform .3s;
  display:flex;flex-direction:column;
}
.code-panel:hover{box-shadow:0 16px 48px rgba(0,0,0,.13),0 6px 16px rgba(0,0,0,.07)}
.code-panel.light{background:#ffffff;border-color:#e0e0e3}
.code-panel.light:hover{box-shadow:0 12px 32px rgba(0,0,0,.08),0 0 0 1px rgba(0,0,0,.05)}
.code-panel.dark{
  border-color:rgba(255,255,255,.06);background:#0a0a0b;border-radius:18px;
  box-shadow:0 25px 50px -12px rgba(0,0,0,.4),0 12px 32px -8px rgba(0,0,0,.25),0 0 0 1px rgba(255,255,255,.06);
}
.code-panel.dark:hover{box-shadow:0 30px 60px -12px rgba(0,0,0,.4),0 16px 32px -8px rgba(0,0,0,.25),0 0 0 1px rgba(255,255,255,.08)}

/* --- Traffic Light Dots --- */
.traffic-lights{display:flex;align-items:center;gap:5px;flex-shrink:0}
.traffic-lights .dot{width:7px;height:7px;border-radius:50%;display:block}
.traffic-lights .dot-red{background:#FF5F57}
.traffic-lights .dot-yellow{background:#FEBC2E}
.traffic-lights .dot-green{background:#28C840}

/* --- Panel Header --- */
.code-panel-header{display:flex;align-items:center;gap:10px;padding:8px 14px;border-bottom:1px solid var(--border)}
.code-panel-header .code-panel-label{margin-left:auto}
.code-panel-header .code-panel-lines{flex-shrink:0}
.code-panel.dark .code-panel-header{border-color:rgba(255,255,255,.08);background:rgba(255,255,255,.02)}
.code-panel.light .code-panel-header{background:#F8FAFA;border-color:#e4e4e7}
.code-panel-label{font-size:11px;font-weight:700;padding:3px 10px;border-radius:100px;text-transform:uppercase;letter-spacing:.04em}
.code-panel-label.bad{background:#fef2f2;color:var(--red)}
.code-panel-label.good{background:rgba(34,197,94,.12);color:var(--green)}
.code-panel-lines{font-size:11px;font-family:var(--mono);font-weight:600}
.code-panel-lines.red{color:var(--red)}
.code-panel-lines.green{color:var(--green)}

/* --- Tabs (IDE-style) --- */
.code-tabs{display:flex;border-bottom:1px solid var(--border);background:transparent}
.code-tabs.light-tabs{background:#F8FAFA;border-color:#e4e4e7}
.code-panel.dark .code-tabs{border-color:rgba(255,255,255,.06);background:#111113}
.code-tab{
  padding:6px 14px;font-size:13px;font-family:var(--mono);font-weight:500;
  background:none;border:none;border-bottom:2px solid transparent;
  cursor:pointer;color:var(--muted);transition:all .2s;
  position:relative;display:inline-flex;align-items:center;gap:5px;
}
.tab-icon{display:inline-block;vertical-align:middle;opacity:.45}
.code-tab.active .tab-icon{opacity:.7}
.cmd-icon-img{opacity:.55}
.code-tab.active{color:var(--fg);border-bottom-color:var(--fg);background:rgba(0,0,0,.02)}
.code-panel.dark .code-tab{color:#52525b}
.code-panel.dark .code-tab.active{color:#e4e4e7;border-bottom-color:#e4e4e7;background:rgba(255,255,255,.03)}
.code-panel.light .code-tab{color:#a1a1aa}
.code-panel.light .code-tab.active{color:var(--fg);border-bottom-color:var(--fg);background:rgba(255,255,255,.6)}

/* --- Truncated Panel (Without Patter) --- */
.code-panel-truncated{position:relative}
.code-panel-truncated .code-block{max-height:320px;overflow:hidden}
.code-panel-truncated::after{
  content:"";position:absolute;bottom:0;left:0;right:0;height:100px;
  background:linear-gradient(to bottom,rgba(255,255,255,0),rgba(255,255,255,.85) 40%,#ffffff);
  pointer-events:none;border-radius:0 0 18px 18px;
}

/* --- Code Block --- */
.code-blocks-wrapper{position:relative;flex:1;display:grid}
.code-blocks-wrapper>.code-block{grid-area:1/1;margin:0}
.code-block{padding:16px 16px 16px 0;font-family:var(--mono);font-size:12px;line-height:1.75;overflow-x:auto;white-space:pre;scrollbar-width:none;-ms-overflow-style:none}
.code-block::-webkit-scrollbar{display:none}
.code-block.hidden{visibility:hidden;pointer-events:none}

/* --- Line Numbers --- */
.line-number{
  display:inline-block;width:28px;text-align:right;margin-right:14px;
  color:#c4c4c8;user-select:none;font-size:10.5px;opacity:.5;
}
.code-panel.dark .line-number{color:#3f3f46;opacity:.8}

/* Light code (without-patter panel) */
.code-block{background:var(--card);color:var(--fg)}
.code-panel.light .code-block{background:#ffffff}
.code-block .kw{color:#7c3aed}.code-block .fn{color:#2563eb}.code-block .str{color:#16a34a}.code-block .cm{color:#a1a1aa}
/* Dark code (with-patter panel) */
.code-panel.dark .code-block{background:#0a0a0b;color:#d4d4d8}
.code-panel.dark .code-block .kw{color:#c084fc}
.code-panel.dark .code-block .fn{color:#60a5fa}
.code-panel.dark .code-block .str{color:#4ade80}
.code-panel.dark .code-block .cm{color:#3f3f46}
.code-savings{padding:8px 14px;border-top:1px solid var(--border);background:#F8FAFA;border-radius:0 0 14px 14px}
.savings-badge{font-size:12px;font-weight:700;color:var(--green);font-family:var(--mono)}

/* --- Feature Grid (1px separator grid) --- */
.feature-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--border);
  border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;text-align:left;margin-top:40px;
}
.feature-card{background:var(--card);padding:28px;transition:background .2s}
.feature-card:hover{background:var(--secondary)}
.feature-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--secondary);border:1px solid var(--border);border-radius:10px;margin-bottom:14px;color:var(--fg)}
.feature-card h3{font-size:14px;font-weight:700;margin-bottom:6px;letter-spacing:-.01em}
.feature-card p{font-size:15px;color:var(--muted);font-weight:500;line-height:1.6}

/* --- Architecture Diagram --- */
.arch-flow{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;padding:36px 0;gap:0}
.arch-node{border:2px solid var(--border);border-radius:var(--radius);padding:18px 24px;text-align:center;min-width:130px;background:var(--card);transition:all .2s}
.arch-node:hover{border-color:var(--muted);box-shadow:0 4px 12px rgba(0,0,0,.05)}
.arch-node-label{font-weight:700;font-size:14px;margin-bottom:3px}
.arch-node-detail{font-size:11px;color:var(--muted);font-family:var(--mono)}
.arch-node-sub-row{display:flex;gap:6px;justify-content:center;margin-top:5px}
.arch-sub{font-size:10px;padding:2px 8px;background:var(--secondary);border:1px solid var(--border);border-radius:6px;color:var(--muted);font-family:var(--mono);font-weight:500}
.arch-arrow{color:var(--border-d);flex-shrink:0;padding:0 2px}
.your-code{border-color:var(--blue);background:#eff6ff}
.sdk-node{border-color:var(--purple);background:#f5f3ff}
.backend-node{border-color:var(--orange);background:#fff7ed}
.phone-node{border-color:var(--green);background:#f0fdf4}

/* --- Horizontal Flow Diagram --- */
.flow-diagram{
  display:flex;align-items:center;justify-content:center;gap:0;
  margin-top:48px;padding:0 16px;position:relative;
}
.flow-column{
  flex:1;max-width:300px;display:flex;flex-direction:column;align-items:center;gap:14px;
  position:relative;z-index:2;
}
.flow-column--center{max-width:280px}
.flow-column-label{
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;
  color:var(--muted);font-family:var(--mono);margin-bottom:2px;
}
.flow-cards{
  display:flex;flex-direction:column;gap:10px;width:100%;
}
.flow-card{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:16px 14px;background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius);text-align:center;transition:all .2s;
}
.flow-card:hover{border-color:var(--muted);box-shadow:0 4px 12px rgba(0,0,0,.05)}
.flow-card--highlight{border-color:var(--border);background:var(--card)}
.flow-card--sdk{
  border-color:var(--blue);background:linear-gradient(135deg,#eff6ff 0%,#f0f9ff 100%);
  padding:24px 18px;gap:8px;
}
.flow-card-icon{
  width:36px;height:36px;display:flex;align-items:center;justify-content:center;
  background:var(--secondary);border:1px solid var(--border);border-radius:10px;
  color:var(--fg);flex-shrink:0;
}
.flow-card-icon--sdk{
  background:rgba(59,130,246,.1);border-color:rgba(59,130,246,.2);color:var(--blue);
  width:42px;height:42px;
}
.flow-card-title{font-size:14px;font-weight:700;color:var(--fg);letter-spacing:-.01em}
.flow-card-title--sdk{font-size:16px}
.flow-card-detail{font-size:12px;color:var(--muted);font-family:var(--mono)}
.flow-card-code{
  font-size:11px;font-family:var(--mono);font-weight:500;
  padding:3px 10px;background:rgba(59,130,246,.08);border:1px solid rgba(59,130,246,.15);
  border-radius:6px;color:var(--blue);
}
.flow-card-chips{display:flex;gap:6px;justify-content:center;margin-top:4px;flex-wrap:wrap}
.flow-chip{
  font-size:10px;padding:3px 10px;background:rgba(59,130,246,.08);
  border:1px solid rgba(59,130,246,.15);border-radius:6px;
  color:var(--blue);font-family:var(--mono);font-weight:600;
}
.flow-card-badge{
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  padding:2px 10px;background:rgba(251,146,60,.12);border:1px solid rgba(251,146,60,.25);
  border-radius:100px;color:var(--orange);font-family:var(--mono);
}
.flow-connector{
  flex-shrink:0;width:80px;display:flex;align-items:stretch;justify-content:center;
}
.flow-connector svg{width:100%;height:auto;overflow:visible}
.flow-card-icon--openai{background:var(--secondary);border-color:var(--border)}
.flow-card-icon--claude{background:var(--secondary);border-color:var(--border)}
.flow-card-icon--twilio{background:var(--secondary);border-color:var(--border)}
.flow-card-icon--telnyx{background:var(--secondary);border-color:var(--border)}

/* Flow diagram responsive */
@media(max-width:900px){
  .flow-diagram{gap:2px;justify-content:center;padding:0;position:relative}
  .flow-column{flex:1;min-width:0;max-width:30%}
  .flow-column--center{max-width:26%;flex:0 0 26%}
  .flow-connector{display:block;width:12px;flex-shrink:0}
  .flow-svg-overlay{display:block}
  .flow-cards{flex-direction:column;gap:3px}
  .flow-card{padding:6px 4px;gap:1px;border-radius:8px}
  .flow-card-icon{width:20px;height:20px;border-radius:5px}
  .flow-card-icon img{width:12px!important;height:12px!important}
  .flow-card-icon svg{width:12px!important;height:12px!important}
  .flow-card-title{font-size:9px}
  .flow-card-detail{font-size:8px}
  .flow-card-code{font-size:7px;padding:1px 4px}
  .flow-card--sdk{max-width:100%;flex-basis:100%;padding:8px 4px;gap:2px;border-radius:8px}
  .flow-card-title--sdk{font-size:10px}
  .flow-chip{font-size:6px;padding:1px 3px}
  .flow-card-badge{font-size:6px;padding:1px 4px}
  .flow-column-label{font-size:7px;letter-spacing:.06em;margin-bottom:1px}
  .flow-column:not(:last-child)::after{display:none}
}
@media(max-width:480px){
  .flow-card--sdk{flex-basis:auto}
  .flow-svg-overlay{display:block}
}

/* --- How-features row --- */
.how-features{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;text-align:left;margin-top:48px}
.how-feature{padding:24px;background:var(--card)}
.how-feature h3{font-size:14px;font-weight:700;margin-bottom:6px}
.how-feature p{font-size:15px;color:var(--muted);font-weight:500;line-height:1.6}

/* --- Pricing --- */
.pricing-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:780px;margin:40px auto 0;text-align:left}
.pricing-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:28px;display:flex;flex-direction:column;transition:all .2s}
.pricing-card:hover{border-color:var(--muted);box-shadow:0 8px 24px rgba(0,0,0,.06)}
.pricing-card.featured{border-color:var(--fg);box-shadow:0 8px 32px rgba(0,0,0,.1)}
.pricing-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.pricing-header h3{font-size:18px;font-weight:700;letter-spacing:-.02em}
.pricing-price{font-size:12px;font-weight:700;padding:3px 12px;background:var(--secondary);border-radius:100px;border:1px solid var(--border)}
.pricing-desc{font-size:15px;color:var(--muted);font-weight:500;margin-bottom:18px;line-height:1.6}
.pricing-features{list-style:none;margin-bottom:20px;flex-grow:1}
.pricing-features li{font-size:15px;font-weight:500;padding:5px 0 5px 22px;position:relative;color:var(--fg)}
.pricing-features li::before{content:"";position:absolute;left:0;top:9px;width:14px;height:14px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2322c55e' stroke-width='3'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-size:contain}

/* --- Use Cases Grid --- */
.cases-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;text-align:left;margin-top:40px}
.case-card{background:var(--card);padding:28px;transition:background .2s}
.case-card:hover{background:var(--secondary)}
.case-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--secondary);border:1px solid var(--border);border-radius:10px;margin-bottom:14px;color:var(--fg)}
.case-card h3{font-size:15px;font-weight:700;margin-bottom:6px}
.case-card p{font-size:15px;color:var(--muted);font-weight:500;line-height:1.6}

/* --- Stats (Manufact giant numbers + dashed separators) --- */
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:40px;text-align:center}
.stat-card{padding:36px 28px;border-left:1px dashed var(--border-d)}
.stat-card:first-child{border-left:none}
.stat-number{font-size:clamp(44px,6vw,68px);font-weight:700;letter-spacing:-.04em;line-height:1;margin-bottom:14px;color:var(--fg)}
.stat-label{font-size:13px;color:var(--muted);line-height:1.5}

/* --- Community --- */
.community-links{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:36px}
.community-card{display:inline-flex;align-items:center;gap:10px;padding:12px 22px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);font-size:14px;font-weight:600}
.community-card:hover{border-color:var(--muted)}

/* --- Final CTA --- */
.final-cta{border-bottom:none}
/* Remove bottom border from last section before footer on all pages */
main .section-panel:last-child{border-bottom:none}
.page-rails > .section-panel:last-child{border-bottom:none}
.final-cta .section-title{max-width:600px;margin:0 auto 14px;font-size:clamp(30px,4.5vw,48px)}
.final-cta .section-subtitle{margin:0 auto 28px}
.highlight{position:relative;display:inline-block}
.highlight::after{content:"";position:absolute;bottom:2px;left:-4px;right:-4px;height:30%;background:rgba(254,240,138,.5);border-radius:4px;z-index:-1}

/* --- Footer --- */
.footer{padding:56px 0 32px;border-top:none;margin-top:20px;overflow:visible;position:relative;z-index:2;background:transparent}
.footer-wave{position:absolute;top:-50px;left:0;right:0;height:100px;pointer-events:none;z-index:3}
.footer-wave-svg{display:block;width:100%;height:auto;max-height:100px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:56px}
.footer-brand{display:flex;flex-direction:column;gap:10px}
.footer-copy{font-size:12px;color:var(--muted)}
.footer-col h4,.footer-col-title{font-size:13px;font-weight:700;margin-bottom:14px}
.footer-col ul{display:flex;flex-direction:column;gap:8px}
.footer-col a{font-size:13px;color:var(--muted);transition:color .2s}
.footer-col a:hover{color:var(--fg)}
.footer-watermark{font-size:clamp(80px,14vw,180px);font-weight:700;color:var(--fg);opacity:.04;text-align:center;line-height:1;letter-spacing:-.05em;user-select:none;pointer-events:none}

/* --- Two-Column Section Layout (Manufact-style) --- */
.section-two-col{
  display:grid;grid-template-columns:3fr 2fr;gap:48px;align-items:center;text-align:left;
}
.section-two-col .section-col-text .section-label{margin-bottom:16px}
.section-two-col .section-col-text .section-title{margin-bottom:16px}
.section-two-col .section-col-text .section-subtitle{margin-bottom:24px}
.feature-bullet-list{list-style:none;padding:0;margin:0 0 28px;display:flex;flex-direction:column;gap:8px}
.feature-bullet-list li{font-size:15px;line-height:1.5;color:var(--fg);font-weight:500;padding-left:16px;position:relative}
.feature-bullet-list li::before{content:"";position:absolute;left:0;top:8px;width:5px;height:5px;border-radius:50%;background:var(--border-d)}
.feature-bullet-detailed{gap:16px}
.feature-bullet-detailed li{font-weight:400;color:#52525b}
.feature-bullet-detailed li strong{color:var(--fg);font-weight:600}
.section-col-actions{display:flex;flex-wrap:wrap;gap:10px}

/* --- Fade-in --- */
.fade-in{opacity:1;transform:none}
.fade-in.d1{transition-delay:.08s}
.fade-in.d2{transition-delay:.16s}
.fade-in.d3{transition-delay:.24s}

/* --- Responsive --- */
@media(max-width:1024px){
  .feature-grid,.how-features{grid-template-columns:repeat(2,1fr)}
  .cases-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
}
@media(max-width:768px){
  .header-inner{height:48px}
  .nav-desktop,.header-actions{display:none}
  .mobile-menu-toggle{display:flex}
  .logo{font-size:17px}
  .logo-icon{height:22px}
  .hero{padding:90px 0 40px;margin:0;min-height:auto;display:block}
  .page-rails{padding:0 10px}
  .hero-card{padding:36px 20px 28px}
  .hero-title{font-size:46px}
  .hero-subtitle{font-size:15px}
  .hero-cta{flex-direction:column;align-items:center;gap:8px}
  .hero-cta .btn-primary,.hero-cta .btn-ghost{width:190px;min-height:44px}
  .install-commands{flex-direction:column;align-items:center;gap:8px}
  .install-cmd{font-size:12px;overflow:hidden;text-overflow:ellipsis;justify-content:center;width:auto}
  .code-panels{grid-template-columns:1fr;gap:20px}
  .code-blocks-wrapper{min-width:0}
  .code-block{font-size:10.5px;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .savings-badge{font-size:11px}
  .code-tab{min-height:44px;padding:10px 16px;font-size:12px}
  .feature-card{padding:24px}
  .case-card{padding:24px}
  .partner-logo{font-size:15px}
  .logo-slide{gap:40px}
  .feature-grid,.how-features,.stats-grid,.pricing-grid,.cases-grid{grid-template-columns:1fr}
  .stat-number{font-size:28px}
  .stat-card{border-left:none;border-top:1px dashed var(--border-d);padding:24px 20px}
  .stat-card:first-child{border-top:none}
  .section-two-col{grid-template-columns:1fr;gap:24px;text-align:center}
  .section-two-col .section-col-visual{order:2}
  .section-two-col .section-col-text{order:1}
  .section-two-col .feature-bullet-list{align-items:flex-start;max-width:360px;margin-left:auto;margin-right:auto}
  .section-two-col .feature-bullet-list li{text-align:left;display:block}
  .section-col-actions{flex-direction:column;align-items:center}
  .section-col-actions .btn-primary,.section-col-actions .btn-ghost{width:100%;min-height:44px}
  .pricing-card{padding:20px}
  .pricing-header{flex-wrap:wrap;gap:8px}
  .arch-flow{flex-direction:column;gap:6px}
  .arch-arrow{transform:rotate(90deg)}
  .footer-grid{grid-template-columns:1fr 1fr 1fr;gap:16px}
  .footer-brand{grid-column:1/-1;gap:12px}
  .section-panel{margin:0;padding:48px 0}
}
@media(max-width:480px){
  .container{padding:0 14px}
  .hero-title{font-size:34px}
  .hero-subtitle{font-size:15px}
  .section-title{font-size:24px}
  .section-subtitle{font-size:14px}
  .section-panel{padding:32px 0}
  .cookie-banner{left:10px;right:10px;max-width:none;bottom:10px}
  .community-links{flex-direction:column;align-items:stretch}
  .community-card{width:100%;justify-content:center}
}

/* --- Features / Build / Inspect / Ship — slightly larger text --- */
#features .section-title,
#inspect .section-title,
#ship .section-title{font-size:clamp(28px,3.8vw,46px)}
#features .section-subtitle,
#inspect .section-subtitle,
#ship .section-subtitle{font-size:19px}
#features .feature-bullet-list li,
#inspect .feature-bullet-list li,
#ship .feature-bullet-list li{font-size:16px}
#features .feature-bullet-list li strong,
#inspect .feature-bullet-list li strong,
#ship .feature-bullet-list li strong{font-size:16px}
#features .section-label,
#inspect .section-label,
#ship .section-label{font-size:12px}

/* --- Use Cases cards — larger text --- */
.case-card h3{font-size:16px}
.case-card p{font-size:16px}

/* --- Inspect Section --- */
.inspect-dashboard-img{
  width:100%;height:auto;border-radius:16px;
  box-shadow:0 12px 40px rgba(0,0,0,.1),0 4px 12px rgba(0,0,0,.05);
  border:1px solid var(--border);
}

/* --- Ship Section (reversed two-col, image bleeds to rail) --- */
#ship{padding-bottom:0;border-bottom:none}
#ship .section-two-col--reversed{align-items:end}
#ship .section-col-text{align-self:center}
.section-two-col--reversed{
  grid-template-columns:2fr 3fr;
}
.ship-visual{
  display:flex;align-items:center;justify-content:flex-start;
  margin-left:-44px;
}
.ship-stack-img{
  width:100%;max-width:460px;height:auto;
}
/* Ship image wrapper for border + dots */
.ship-img-frame{
  position:relative;display:inline-block;
  border:1px solid var(--border);border-radius:4px;
  overflow:visible;
}
.ship-img-frame img{display:block;border-radius:3px}
.ship-img-frame::before,.ship-img-frame::after,
.ship-img-frame .ship-dot-bl,.ship-img-frame .ship-dot-br{
  position:absolute;width:7px;height:7px;border-radius:50%;background:var(--border-d);z-index:4;
}
.ship-img-frame::before{content:"";top:-3px;left:-3px}
.ship-img-frame::after{content:"";top:-3px;right:-3px}
.ship-img-frame .ship-dot-bl{bottom:-3px;left:-3px}
.ship-img-frame .ship-dot-br{bottom:-3px;right:-3px}
@media(max-width:768px){
  .section-two-col--reversed{grid-template-columns:1fr;text-align:center}
  .section-two-col--reversed .section-col-visual{order:2}
  .section-two-col--reversed .section-col-text{order:1}
  .ship-visual{margin-left:0;justify-content:center}
  .ship-stack-img{max-width:280px}
}

/* --- Cloud Feature Cards --- */
.cloud-feature-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:32px;display:flex;flex-direction:column;gap:20px}
.cloud-feature-icon{width:48px;height:48px;background:var(--secondary);border:1px solid var(--border);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--fg)}
.cloud-feature-detail{display:flex;align-items:baseline;gap:8px}
.cloud-metric{font-size:28px;font-weight:700;color:var(--fg);letter-spacing:-.02em}
.cloud-metric-label{font-size:13px;color:var(--muted)}

/* --- Waitlist Form --- */
.waitlist-form{max-width:440px;margin:0 auto;width:100%}
.waitlist-inputs{display:flex;gap:8px}
.waitlist-input{flex:1;padding:12px 16px;border:1px solid var(--border);border-radius:100px;font-size:14px;font-family:inherit;outline:none;transition:border-color .2s;background:#fff}
.waitlist-input:focus{border-color:var(--fg)}
.waitlist-status{font-size:13px;margin-top:8px;color:var(--muted);text-align:center}
.waitlist-status.success{color:var(--accent)}
.waitlist-status.error{color:#ef4444}
@media(max-width:480px){.waitlist-inputs{flex-direction:column}.waitlist-inputs .btn-primary{width:100%}}

/* --- Coming Soon Badge --- */
.badge-coming-soon{color:#f97316!important;background:rgba(249,115,22,.08)!important;border-color:rgba(249,115,22,.2)!important;cursor:default}

/* --- Product Hero --- */
.product-hero{padding:120px 0 60px;border-left:1px solid var(--border);border-right:1px solid var(--border);border-bottom:1px solid var(--border)}

/* --- Footer (multi-page, extends homepage footer) --- */
@media(max-width:768px){
  .product-hero{padding:90px 0 40px}
}
@media(max-width:480px){
  .cloud-metric{font-size:22px}
}
