:root{
  --bg:#eaf2ff; --surface:#ffffff; --ink:#1e293b; --muted:#64748b;
  --accent:#4f46e5; --accent-2:#2563eb; --line:#c7d7f5; --line-soft:#e4ecfb;
  --ok:#3f7d58; --warn:#b45309; --danger:#b91c1c;
  --header-h:60px; --footer-h:54px;
  --r:14px; --r-sm:9px;
  --shadow:0 1px 2px rgba(30,41,59,.06), 0 8px 24px rgba(30,41,59,.07);
  --font-display:"Poppins",-apple-system,Segoe UI,Roboto,sans-serif;
  --font-body:"Inter",-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--font-body);color:var(--ink);background:var(--bg);
  line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,.display{font-family:var(--font-display);font-weight:700;line-height:1.1}
button{font-family:inherit;cursor:pointer}
.hidden{display:none !important}

/* signature: faint planner-grid motif */
.grid-motif{background-image:linear-gradient(var(--line-soft) 1px,transparent 1px),
  linear-gradient(90deg,var(--line-soft) 1px,transparent 1px);
  background-size:28px 28px}

header.app{position:sticky;top:0;z-index:30;height:var(--header-h);display:flex;
  align-items:center;gap:14px;padding:0 20px;background:rgba(255,255,255,.86);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line-soft)}
.brand{font-family:var(--font-display);font-weight:700;font-size:18px;display:flex;align-items:center;gap:8px}
.brand .mark{width:26px;height:26px;border-radius:7px;background:var(--accent);
  display:inline-grid;place-items:center;color:#fff;font-size:14px}
.spacer{flex:1}
.btn{border:1px solid transparent;border-radius:var(--r-sm);padding:9px 16px;font-weight:600;
  font-size:14px;background:var(--accent);color:#fff;transition:.15s}
.btn:hover{background:var(--accent-2)}
.btn.ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn.ghost:hover{background:#fff}
.btn.sm{padding:6px 11px;font-size:13px}
.btn:disabled{opacity:.5;cursor:not-allowed}
.pill{font-size:12px;font-weight:700;padding:3px 9px;border-radius:99px;background:#eef2ff;color:var(--accent)}

/* landing */
.wrap{max-width:1100px;margin:0 auto;padding:0 22px}
.hero{padding:74px 0 40px;display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center}
.eyebrow{letter-spacing:.16em;text-transform:uppercase;font-size:12px;font-weight:700;color:var(--accent)}
.hero h1{font-size:48px;margin:10px 0 14px}
.hero p.lead{font-size:18px;color:var(--muted);max-width:46ch}
.hero .cta{display:flex;gap:12px;margin-top:22px;flex-wrap:wrap}
.preview-card{background:var(--surface);border-radius:var(--r);box-shadow:var(--shadow);
  border:1px solid var(--line-soft);padding:18px;aspect-ratio:3/4;overflow:hidden;position:relative}
.preview-card .pc-cover{height:100%;border-radius:10px;background:#f6f1e9;padding:22px;display:flex;
  flex-direction:column;justify-content:flex-end}
.preview-card .pc-cover .t{font-family:var(--font-display);font-weight:700;font-size:26px;color:#3a3027}
.preview-card .pc-cover .y{color:#c0703a;font-weight:700;margin-top:6px}

.section{padding:46px 0}
.section h2{font-size:30px;margin:0 0 8px}
.section .sub{color:var(--muted);margin:0 0 26px;max-width:60ch}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--r);padding:20px;box-shadow:var(--shadow)}
.card .n{font-family:var(--font-display);color:var(--accent);font-weight:700;font-size:13px}
.card h3{font-size:18px;margin:8px 0 6px}
.card p{color:var(--muted);margin:0;font-size:14px}
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.tier{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--r);padding:24px;box-shadow:var(--shadow)}
.tier.featured{border-color:var(--accent);box-shadow:0 10px 30px rgba(79,70,229,.16)}
.tier h3{font-size:20px;margin:0}
.tier .price{font-family:var(--font-display);font-size:34px;font-weight:700;margin:8px 0}
.tier ul{list-style:none;padding:0;margin:14px 0 18px}
.tier li{padding:6px 0 6px 24px;position:relative;font-size:14px;color:#334155}
.tier li:before{content:"✓";position:absolute;left:0;color:var(--ok);font-weight:700}

footer.app{height:var(--footer-h);display:flex;align-items:center;justify-content:center;
  font-size:12px;color:var(--muted);border-top:1px solid var(--line-soft);margin-top:30px}

/* ---------- editor ---------- */
.editor{display:grid;grid-template-columns:260px 1fr 300px;height:calc(100vh - var(--header-h));}
.panel{overflow:auto;padding:16px;background:var(--surface)}
.panel.left{border-right:1px solid var(--line-soft)}
.panel.right{border-left:1px solid var(--line-soft)}
.panel.center{background:var(--bg);padding:0;display:flex;flex-direction:column}
.panel h4{font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin:0 0 12px}
.seclist{list-style:none;margin:0;padding:0}
.seclist li{border:1px solid var(--line-soft);border-radius:var(--r-sm);padding:10px 12px;margin-bottom:8px;
  background:#fff;display:flex;align-items:center;gap:8px;cursor:grab}
.seclist li.sel{border-color:var(--accent);background:#f5f6ff}
.seclist li .grip{color:#b9c2d0}
.seclist li .nm{flex:1;font-size:14px;font-weight:600}
.seclist li .nm small{display:block;font-weight:400;color:var(--muted);font-size:11px}
.seclist li .x{color:var(--muted);font-size:16px;line-height:1;border:0;background:none}
.addrow{display:flex;gap:8px;margin-top:6px}
.addrow select{flex:1}
select,input[type=text],input[type=number]{width:100%;padding:8px 10px;border:1px solid var(--line);
  border-radius:var(--r-sm);font-family:inherit;font-size:14px;background:#fff;color:var(--ink)}
label.fld{display:block;font-size:12px;font-weight:600;color:var(--muted);margin:12px 0 5px}
.previewbar{display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:1px solid var(--line-soft);background:#fff}
.previewbar .title{font-weight:600}
iframe.preview{flex:1;width:100%;border:0;background:#fff}
.exportgrid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}
.lockbadge{font-size:11px;color:var(--warn)}
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;
  padding:10px 16px;border-radius:var(--r-sm);font-size:14px;z-index:80;box-shadow:var(--shadow)}

/* overlay */
.overlay{position:fixed;inset:0;background:rgba(234,242,255,.82);backdrop-filter:blur(3px);
  z-index:90;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:16px}
.overlay .box{background:#fff;border-radius:var(--r);box-shadow:var(--shadow);padding:26px 30px;text-align:center;min-width:300px}
.overlay .msg{font-weight:600;margin-bottom:14px}
.bar{height:8px;border-radius:99px;background:var(--line-soft);overflow:hidden}
.bar > i{display:block;height:100%;width:30%;background:var(--accent);border-radius:99px;transition:width .25s}
.overlay .hint{font-size:12px;color:var(--muted);margin-top:10px}

/* modal */
.modal{position:fixed;inset:0;background:rgba(15,23,42,.4);z-index:85;display:flex;align-items:center;justify-content:center}
.modal .sheet{background:#fff;border-radius:var(--r);box-shadow:var(--shadow);padding:26px;width:min(440px,92vw)}
.modal h3{margin:0 0 6px}
.modal .row{display:flex;gap:10px;margin-top:10px}
.tabs{display:none}

/* survey */
.center-stage{max-width:680px;margin:0 auto;padding:42px 22px}
.chip{display:inline-block;border:1px solid var(--line);border-radius:99px;padding:8px 14px;margin:5px 6px 0 0;
  background:#fff;font-size:14px;cursor:pointer}
.chip.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.nichegrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-top:20px}
.niche{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r);padding:18px;text-align:center;cursor:pointer;transition:.15s}
.niche:hover{border-color:var(--accent);transform:translateY(-2px)}
.niche .ic{font-size:26px}
.niche .lb{font-weight:600;margin-top:8px;font-size:14px}
.q{margin:22px 0}
.q .qlabel{font-weight:600;margin-bottom:6px}

@media(max-width:880px){
  .hero{grid-template-columns:1fr}
  .steps,.tiers{grid-template-columns:1fr}
  .editor{grid-template-columns:1fr;height:auto}
  .panel.left,.panel.right{display:none}
  .panel.left.show,.panel.right.show{display:block}
  .panel.center{min-height:60vh}
  .tabs{display:flex;position:sticky;top:var(--header-h);z-index:20;background:#fff;border-bottom:1px solid var(--line-soft)}
  .tabs button{flex:1;border:0;background:none;padding:12px;font-weight:600;color:var(--muted)}
  .tabs button.on{color:var(--accent);box-shadow:inset 0 -2px 0 var(--accent)}
}
