:root{
  --orange:#FF7A1A;
  --orange2:#EA580C;
  --orange3:#C2410C;
  --orange-soft:#FFF1E6;
  --purple:#261447;
  --purple2:#160828;
  --purple3:#10081E;
  --purple-soft:#EDE6F7;
  --purple4:#4A2290;
  --cream:#FFF4E6;
  --cream2:#FFF9F0;
  --cream3:#FFFDF8;
  --black:#151515;
  --white:#FFFFFF;
  --muted:#6B6473;
  --ink:#1F1A2A;
  --ink2:#3F3650;
  --line:#E9DCCB;
  --line2:#F3E8D8;
  --line3:#D8CCB7;
  --green:#16A34A;
  --green-soft:#E7F7EC;
  --red:#DC2626;
  --red-soft:#FDECEC;
  --blue:#2563EB;
  --blue-soft:#EFF4FF;
  --yellow:#D97706;
  --yellow-soft:#FFF4DC;
  --surface:rgba(255,255,255,.78);
  --shadow:0 24px 70px rgba(38,20,71,.12);
  --shadow2:0 12px 34px rgba(38,20,71,.08);
  --shadow3:0 4px 14px rgba(38,20,71,.06);
  --shadow-orange:0 16px 30px rgba(255,122,26,.25);
  --shadow-purple:0 16px 30px rgba(38,20,71,.20);
  --radius:24px;
  --r-md:14px;
  --r-sm:10px;
  --font:"Prompt","IBM Plex Sans Thai",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font);color:var(--black);background:
  radial-gradient(circle at 8% 0%,rgba(255,122,26,.20),transparent 28%),
  radial-gradient(circle at 92% 6%,rgba(38,20,71,.14),transparent 32%),
  linear-gradient(135deg,#FFF9EF 0%,#FFF4E6 46%,#FFFDF8 100%);
  min-height:100vh;font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased}
body:before{content:"";position:fixed;inset:0;pointer-events:none;background-image:linear-gradient(rgba(38,20,71,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(38,20,71,.045) 1px,transparent 1px);background-size:36px 36px;mask-image:linear-gradient(to bottom,rgba(0,0,0,.45),transparent 75%);z-index:0}
button,input,textarea,select{font:inherit;color:inherit}
button{cursor:pointer;border:0;background:transparent}
a{color:inherit;text-decoration:none}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:rgba(38,20,71,.18);border-radius:99px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:rgba(38,20,71,.32);background-clip:padding-box;border:2px solid transparent}
::-webkit-scrollbar-track{background:transparent}

/* =============== APP SHELL =============== */
.app{position:relative;z-index:1;min-height:100vh;display:flex}
.app.no-shell .sidebar{display:none}
.app.no-shell .main{padding:0}
.app.no-shell .topbar{display:none}

/* =============== SIDEBAR =============== */
.sidebar{width:280px;flex:0 0 280px;position:sticky;top:0;align-self:flex-start;height:100vh;padding:20px 14px;display:flex;flex-direction:column;gap:14px;background:
  radial-gradient(circle at 26% 0%,rgba(255,122,26,.24),transparent 28%),
  linear-gradient(180deg,#160828 0%,#261447 52%,#10081E 100%);color:white;box-shadow:18px 0 60px rgba(38,20,71,.22);overflow:hidden}
.sidebar::after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 80% 90%,rgba(74,34,144,.4),transparent 40%)}
.sidebar > *{position:relative;z-index:1}
.brand{display:flex;align-items:center;gap:10px;padding:6px 6px 12px}
.logoIcon{flex-shrink:0;display:inline-block}
.logoIcon svg{display:block}
.logoWord{font-family:var(--font);font-weight:800;letter-spacing:-.03em;line-height:1;display:inline-flex;gap:1px;font-size:24px;white-space:nowrap}
.logoWord .a{color:var(--orange)}
.logoWord .b{color:var(--purple)}
.sidebar .logoWord .b{color:#fff}
.landingFoot .logoWord{font-size:14px}
.authSide .logoWord .b{color:#fff}
.logoWord.lg{font-size:30px}
.logoMark{width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,var(--orange),#ff4b00);display:grid;place-items:center;box-shadow:0 16px 28px rgba(255,122,26,.30),inset 0 1px 0 rgba(255,255,255,.45);position:relative;color:#fff;font-weight:800;font-size:22px;letter-spacing:-.10em;padding-right:5px;flex-shrink:0}
.logoMark::after{content:"▶";font-size:11px;position:absolute;right:6px;top:18px;color:var(--purple);font-weight:900}
.brandText b{font-size:18px;letter-spacing:-.02em;display:block;line-height:1.1}
.brandText span{display:block;color:#D7CEE6;font-size:11px;margin-top:2px}
.workspace{padding:10px 12px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);border-radius:16px;display:flex;gap:10px;align-items:center;cursor:pointer;transition:.15s ease}
.workspace:hover{background:rgba(255,255,255,.10)}
.workspace .mark{width:36px;height:36px;border-radius:11px;background:linear-gradient(135deg,#FFD1A4,#FF7A1A);color:#7C2D12;display:grid;place-items:center;font-weight:800;font-size:13px;flex-shrink:0}
.workspace .wsInfo{flex:1;min-width:0}
.workspace .wsInfo b{font-size:13px;display:block;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.workspace small{color:#CFC3DF;font-size:10.5px}
.navScroll{flex:1;overflow-y:auto;margin:0 -6px;padding:0 6px}
.navScroll::-webkit-scrollbar{width:6px}
.navScroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,.10)}
.navGroup{margin-top:4px}
.navLabel{padding:8px 12px 6px;color:#9C8BB8;font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase}
.nav{display:flex;flex-direction:column;gap:3px}
.navBtn{color:#F8F2FF;border-radius:13px;padding:9px 12px;display:flex;align-items:center;gap:10px;text-align:left;font-weight:600;font-size:13px;transition:.15s ease;width:100%}
.navBtn:hover{background:rgba(255,255,255,.08)}
.navBtn.active{background:linear-gradient(135deg,var(--orange),#ff4b00);box-shadow:0 14px 30px rgba(255,122,26,.28)}
.navBtn .navIco{width:26px;height:26px;display:grid;place-items:center;background:rgba(255,255,255,.10);border-radius:9px;flex-shrink:0;color:#fff}
.navBtn.active .navIco{background:rgba(255,255,255,.20)}
.navBtn .navLab{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tag{font-size:9px;padding:2px 6px;border-radius:999px;background:rgba(255,122,26,.18);color:#ffccaa;border:1px solid rgba(255,122,26,.26);font-weight:700;letter-spacing:.05em}
.badge{font-size:10px;min-width:20px;height:18px;padding:0 6px;border-radius:999px;background:rgba(255,255,255,.14);display:inline-flex;align-items:center;justify-content:center;font-weight:700}
.sidebarFoot{margin-top:auto;display:flex;flex-direction:column;gap:8px}
.credCard{padding:12px;border-radius:14px;background:linear-gradient(135deg,rgba(255,122,26,.16),rgba(255,75,0,.06));border:1px solid rgba(255,122,26,.25)}
.credLabel{font-size:11px;color:#FFD1A4;font-weight:600;display:flex;justify-content:space-between}
.credBar{height:6px;background:rgba(255,255,255,.10);border-radius:99px;overflow:hidden;margin:8px 0 6px}
.credFill{height:100%;width:68%;background:linear-gradient(90deg,#FFD1A4,var(--orange));border-radius:99px}
.credNum{font-size:18px;font-weight:800;color:white;letter-spacing:-.01em}
.credSub{color:#CFC3DF;font-size:11px}
.logout{border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.05);color:white;border-radius:14px;padding:10px 12px;text-align:left;font-weight:600;display:flex;gap:10px;align-items:center;font-size:13px}
.logout:hover{background:rgba(255,255,255,.10)}

/* =============== MAIN + TOPBAR =============== */
.main{flex:1;min-width:0;padding:24px 40px 56px;display:flex;flex-direction:column}
.mainInner{max-width:1480px;width:100%;margin:0 auto}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;gap:14px}
.topLeft{display:flex;align-items:center;gap:12px;min-width:0}
.breadcrumb{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13px;font-weight:600;white-space:nowrap}
.breadcrumb .crumb-current{color:var(--purple);font-weight:700}
.topRight{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.search{height:42px;width:260px;border:1px solid var(--line);background:rgba(255,255,255,.75);border-radius:13px;display:flex;align-items:center;gap:10px;padding:0 14px;box-shadow:var(--shadow3);backdrop-filter:blur(12px);min-width:0}
.search input{border:0;background:transparent;outline:0;width:100%;font-size:13px}
.search input::placeholder{color:var(--muted)}
.searchKbd{font-family:var(--mono);font-size:10px;color:var(--muted);background:rgba(38,20,71,.06);padding:2px 6px;border-radius:5px;border:1px solid var(--line2)}
.iconBtn{height:42px;width:42px;border:1px solid var(--line);background:rgba(255,255,255,.75);border-radius:13px;display:grid;place-items:center;box-shadow:var(--shadow3);position:relative;color:var(--purple)}
.iconBtn:hover{background:rgba(255,255,255,1)}
.iconBtn.bell::after{content:"";position:absolute;top:9px;right:11px;width:8px;height:8px;background:var(--orange);border-radius:99px;border:2px solid #fff}
.profilePill{height:42px;border:1px solid var(--line);background:rgba(255,255,255,.75);border-radius:13px;display:flex;align-items:center;gap:8px;padding:3px 12px 3px 4px;box-shadow:var(--shadow3);cursor:pointer;font-weight:600;font-size:13px;color:var(--purple)}
.profilePill .av{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#FFD3A8,#F97316);display:grid;place-items:center;color:#7C2D12;font-weight:800;font-size:13px}
.profilePill small{display:block;font-size:10px;color:var(--muted);font-weight:500;line-height:1}
.lang{display:inline-flex;border:1px solid var(--line);padding:3px;background:rgba(255,255,255,.7);border-radius:999px;height:42px;align-items:center;box-shadow:var(--shadow3)}
.lang button{border-radius:999px;padding:5px 10px;font-weight:700;font-size:11px;color:var(--muted);height:32px}
.lang button.active{background:var(--purple);color:#fff;box-shadow:0 4px 12px rgba(38,20,71,.25)}

/* combined channel widget */
.chWidget{display:inline-flex;align-items:center;gap:10px;height:42px;padding:0 12px 0 8px;border-radius:13px;border:1px solid var(--line);background:rgba(255,255,255,.75);box-shadow:var(--shadow3);font-size:12px;font-weight:700;color:var(--purple);cursor:pointer}
.chStack{display:flex;align-items:center;gap:6px}
.chStack > div{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow3);position:relative}
.chStack > div.off{background:var(--cream2);opacity:.85}
.chStack .chDot{position:absolute;bottom:-2px;right:-2px;width:9px;height:9px;border-radius:99px;background:var(--green);border:1.5px solid #fff}
.chStack .chDot.warn{background:var(--yellow)}
.chWidget small{display:block;font-size:10px;color:var(--muted);font-weight:600;line-height:1.2;margin-top:1px}

/* channel perm pills next to bell (legacy) */
.chPerm{display:inline-flex;align-items:center;gap:8px;height:42px;padding:0 10px 0 8px;border-radius:13px;border:1px solid var(--line);background:rgba(255,255,255,.75);box-shadow:var(--shadow3);font-size:11px;font-weight:600;color:var(--purple)}
.chPerm.warn{background:var(--yellow-soft);border-color:#FCD9A8;color:#92400E}
.chPerm .chIco{width:24px;height:24px;border-radius:7px;display:grid;place-items:center}
.chPerm small{display:block;font-size:9px;color:var(--green);font-weight:600;line-height:1}
.chPerm.warn small{color:var(--yellow)}
.chPerm .chDot{width:6px;height:6px;border-radius:99px;background:var(--green);box-shadow:0 0 0 3px rgba(22,163,74,.18)}
.chPerm.warn .chDot{background:var(--yellow);box-shadow:0 0 0 3px rgba(217,119,6,.18)}

/* =============== PAGE HEADER =============== */
.sectionHead{display:flex;justify-content:space-between;gap:20px;margin-bottom:28px;align-items:flex-end;flex-wrap:wrap}
.kicker{color:var(--orange);font-weight:800;font-size:11px;letter-spacing:.14em;text-transform:uppercase}
.title{font-size:36px;line-height:1.08;margin:6px 0 8px;color:var(--purple);font-weight:800;letter-spacing:-.04em}
.title .star{color:var(--orange);font-weight:400;font-size:.85em;margin-left:6px}
.subtitle{color:var(--muted);font-size:14.5px;max-width:720px;margin:0}
.actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* =============== CARDS =============== */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow2);backdrop-filter:blur(16px);padding:24px;position:relative;overflow:visible;transition:box-shadow .2s ease}
.card.solid{background:#fff}
.card.tight{padding:18px}
.card.flat{box-shadow:none}
.cardHeader{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:14px}
.cardTitle{font-size:16px;color:var(--purple);font-weight:800;margin:0;display:flex;align-items:center;gap:8px;letter-spacing:-.01em}
.cardSub{font-size:12px;color:var(--muted);margin:2px 0 0}
.micro{font-size:12px;color:var(--muted)}
.eyebrow{font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.divider{height:1px;background:var(--line);margin:14px 0;border:0}
.divider.dashed{background:transparent;border-top:1px dashed var(--line)}

/* =============== GRID =============== */
.grid{display:grid;gap:20px}
.g2{grid-template-columns:repeat(2,minmax(0,1fr))}
.g3{grid-template-columns:repeat(3,minmax(0,1fr))}
.g4{grid-template-columns:repeat(4,minmax(0,1fr))}
.g5{grid-template-columns:repeat(5,minmax(0,1fr))}
.g6{grid-template-columns:repeat(6,minmax(0,1fr))}
.g12{grid-template-columns:repeat(12,minmax(0,1fr))}
.span3{grid-column:span 3}.span4{grid-column:span 4}.span5{grid-column:span 5}.span6{grid-column:span 6}.span7{grid-column:span 7}.span8{grid-column:span 8}.span9{grid-column:span 9}
.split{display:flex;align-items:center;justify-content:space-between;gap:12px}
.row{display:flex;align-items:center;gap:10px}

/* =============== BUTTONS =============== */
.btn{border:1px solid transparent;border-radius:13px;height:40px;padding:0 16px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;font-size:13px;transition:.15s ease;background:#fff;color:var(--purple);white-space:nowrap}
.btn:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(38,20,71,.10)}
.btn:active{transform:translateY(0)}
.btn.primary{background:linear-gradient(135deg,var(--orange),#ff4b00);color:#fff;box-shadow:var(--shadow-orange)}
.btn.primary:hover{background:linear-gradient(135deg,#FF8A30,#ff5810);box-shadow:0 18px 36px rgba(255,122,26,.32)}
.btn.purple{background:linear-gradient(135deg,var(--purple4),var(--purple));color:#fff;box-shadow:var(--shadow-purple)}
.btn.outline{border-color:var(--line);background:rgba(255,255,255,.70)}
.btn.outline:hover{background:#fff}
.btn.ghost{background:transparent;color:var(--purple)}
.btn.ghost:hover{background:rgba(38,20,71,.04)}
.btn.blue{background:#1877F2;color:#fff}
.btn.green{background:var(--green);color:#fff}
.btn.danger{background:var(--red);color:#fff}
.btn.lg{height:48px;padding:0 22px;font-size:14px;border-radius:14px}
.btn.sm{height:32px;padding:0 12px;font-size:12px;border-radius:10px}
.btn.iconOnly{padding:0;width:40px}
.btn.iconOnly.sm{width:32px}

/* =============== PILLS / TAGS =============== */
.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:#fff;border:1px solid var(--line);font-size:11.5px;font-weight:700;color:var(--purple);white-space:nowrap}
.pill.orange{background:var(--orange-soft);color:#9A3412;border-color:#FED7AA}
.pill.blue{background:var(--blue-soft);color:#1D4ED8;border-color:#DBE5FF}
.pill.green{background:var(--green-soft);color:#166534;border-color:#C8EBD2}
.pill.red{background:var(--red-soft);color:#991B1B;border-color:#FBCFCE}
.pill.yellow{background:var(--yellow-soft);color:#92400E;border-color:#FCD9A8}
.pill.dark{background:var(--purple);color:white;border-color:var(--purple)}
.pill.lavender{background:var(--purple-soft);color:var(--purple);border-color:#D8C7EE}
.pill.lg{padding:6px 12px;font-size:12px}
.dot{width:7px;height:7px;border-radius:99px;display:inline-block}

/* =============== TABS =============== */
.tabs{display:inline-flex;gap:4px;padding:4px;border:1px solid var(--line);background:rgba(255,255,255,.7);border-radius:13px}
.tab{border-radius:10px;padding:7px 12px;font-weight:700;color:var(--muted);font-size:12.5px;display:inline-flex;align-items:center;gap:6px}
.tab:hover{color:var(--purple)}
.tab.active{background:var(--purple);color:#fff;box-shadow:0 4px 10px rgba(38,20,71,.22)}
.tabs.lg .tab{padding:9px 16px;font-size:13.5px}

/* =============== INPUTS =============== */
.input,.textarea,.select{width:100%;border:1px solid var(--line);background:rgba(255,255,255,.86);border-radius:12px;padding:10px 12px;outline:0;color:var(--ink);font-size:13.5px;transition:.15s ease}
.textarea{min-height:90px;resize:vertical;line-height:1.55}
.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%236B6473' d='M6 7L0 1l1.4-1L6 4.2 10.6 0 12 1z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
.input::placeholder,.textarea::placeholder{color:#A39BAE}
.input:focus,.textarea:focus,.select:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,122,26,.15)}
.label{display:block;font-size:12.5px;font-weight:700;color:var(--purple);margin-bottom:6px}
.field{margin-bottom:12px}
.hint{font-size:11.5px;color:var(--muted);margin-top:5px}

/* =============== TOGGLE / CHECKBOX =============== */
.toggle{width:38px;height:22px;border-radius:999px;background:var(--line);position:relative;cursor:pointer;flex-shrink:0;transition:.15s}
.toggle.on{background:var(--orange)}
.toggle::after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:.15s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle.on::after{left:19px}
.check{width:18px;height:18px;border-radius:6px;border:2px solid var(--line3);background:#fff;display:inline-grid;place-items:center;flex-shrink:0;cursor:pointer;transition:.15s}
.check.on{background:var(--orange);border-color:var(--orange)}
.check.on::after{content:"✓";color:#fff;font-size:11px;font-weight:900;line-height:1}

/* =============== KPI / METRICS =============== */
.metric{display:flex;align-items:center;gap:14px}
.metricIcon{width:48px;height:48px;border-radius:14px;background:var(--purple-soft);color:var(--purple);display:grid;place-items:center;font-size:20px;flex-shrink:0}
.metricIcon.orange{background:var(--orange-soft);color:var(--orange3)}
.metricIcon.blue{background:var(--blue-soft);color:var(--blue)}
.metricIcon.green{background:var(--green-soft);color:#166534}
.metricIcon.red{background:var(--red-soft);color:#991B1B}
.metricIcon.purple{background:var(--purple);color:#fff}
.metricVal{font-size:28px;font-weight:800;color:var(--purple);letter-spacing:-.02em;line-height:1.1}
.metricLab{font-size:12px;color:var(--muted);margin-top:2px;font-weight:600}
.delta{font-size:11.5px;font-weight:700;display:inline-flex;align-items:center;gap:3px;margin-top:4px}
.delta.up{color:var(--green)}
.delta.down{color:var(--red)}

/* =============== LANDING =============== */
.hero{position:relative;padding:32px 48px 36px;border-radius:28px;background:linear-gradient(135deg,#FFF1E6 0%,#FFE4CA 50%,#FFD1A4 100%);overflow:hidden;border:1px solid var(--line);box-shadow:0 30px 80px rgba(38,20,71,.10)}
.heroOrb{position:absolute;border-radius:50%;filter:blur(60px);pointer-events:none}
.heroOrb.o1{top:-80px;right:-40px;width:340px;height:340px;background:radial-gradient(circle,rgba(255,122,26,.55),transparent 70%)}
.heroOrb.o2{bottom:-100px;left:-60px;width:380px;height:380px;background:radial-gradient(circle,rgba(38,20,71,.35),transparent 70%)}
.hero > *:not(.heroOrb){position:relative;z-index:2}
.heroPill{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;border-radius:999px;background:rgba(255,255,255,.65);border:1px solid rgba(255,255,255,.9);backdrop-filter:blur(8px);font-weight:700;font-size:12px;color:var(--purple);box-shadow:var(--shadow3)}
.heroPill .dot{background:var(--orange);box-shadow:0 0 0 3px rgba(255,122,26,.25)}
.heroLogo{font-family:var(--font);font-weight:800;font-size:58px;letter-spacing:-.05em;line-height:.95;display:flex;gap:6px;margin:10px 0 4px;color:var(--purple)}
.heroLogo span:first-child{color:var(--orange)}
.heroH1{font-size:44px;font-weight:800;letter-spacing:-.04em;line-height:1.04;color:var(--purple);margin:10px 0 14px;max-width:720px}
.heroH1 em{font-style:normal;background:linear-gradient(135deg,var(--orange),#ff4b00);-webkit-background-clip:text;background-clip:text;color:transparent}
.heroLead{font-size:15.5px;line-height:1.6;color:var(--ink2);max-width:560px;margin:0 0 20px}
.heroCtas{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.heroTrust{display:flex;gap:20px;margin-top:14px;font-size:12.5px;color:var(--ink2);font-weight:600;flex-wrap:wrap}
.heroTrust span{display:inline-flex;align-items:center;gap:6px}
.heroTrust span::before{content:"✓";color:var(--green);font-weight:900}

/* Landing nav */
.landingNav{position:sticky;top:0;z-index:10;background:rgba(255,249,239,.85);backdrop-filter:blur(14px);border-bottom:1px solid rgba(38,20,71,.06)}
.landingNavInner{max-width:1280px;margin:0 auto;padding:14px 32px;display:flex;align-items:center;gap:24px}
.landingNav .logoMark{width:42px;height:42px;border-radius:12px}
.landingNav .navBrand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px;color:var(--purple);letter-spacing:-.02em}
.landingNav nav{display:flex;gap:24px;margin-left:18px}
.landingNav nav a{color:var(--ink2);font-weight:600;font-size:13.5px}
.landingNav nav a:hover{color:var(--orange)}
.landingMain{max-width:1280px;margin:0 auto;padding:0 32px 48px}

/* Hero preview card */
.heroPreview{position:relative;perspective:1200px}
.previewCard{background:#fff;border-radius:22px;box-shadow:0 30px 80px rgba(38,20,71,.18),0 8px 20px rgba(38,20,71,.10);border:1px solid var(--line);overflow:hidden;transform:rotate(-2deg);transition:.4s}
.previewCard:hover{transform:rotate(0deg)}
.previewHead{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--line2)}
.previewBody{padding:16px}
.previewImg{aspect-ratio:4/3;border-radius:14px;background:linear-gradient(135deg,#FFEDD5,#FED7AA 50%,#FECDD3);position:relative;overflow:hidden;border:1px solid var(--line2)}
.previewBottle{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:130px;height:160px;border-radius:18px;background:linear-gradient(180deg,#FFFBEB,#FED7AA);box-shadow:0 14px 40px -10px rgba(124,45,18,.30);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#7C2D12}
.previewBottle b{font-size:26px;font-weight:800;margin-top:6px}
.floatPill{position:absolute;background:#fff;border:1px solid var(--line);border-radius:14px;padding:8px 12px;font-size:12px;font-weight:600;display:flex;align-items:center;gap:8px;box-shadow:var(--shadow2);z-index:2}
.floatPill.top{top:-14px;left:-12px}
.floatPill.bot{bottom:-18px;right:-8px}

/* Feature card */
.featCard{padding:28px;background:var(--surface);border:1px solid var(--line);border-radius:24px;backdrop-filter:blur(12px);box-shadow:var(--shadow2);transition:.2s}
.featCard:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.featCard .num{font-family:var(--mono);font-size:11px;color:var(--muted)}
.featCard .featIcon{width:52px;height:52px;border-radius:14px;background:var(--orange-soft);color:var(--orange);display:grid;place-items:center;font-size:22px;margin-bottom:18px}
.featCard.b .featIcon{background:var(--blue-soft);color:var(--blue)}
.featCard.g .featIcon{background:var(--green-soft);color:var(--green)}
.featCard.p .featIcon{background:var(--purple);color:#fff}
.featCard h3{font-size:22px;color:var(--purple);font-weight:800;letter-spacing:-.02em;margin:0 0 10px}

/* Final CTA */
.finalCta{margin:64px 0 0;padding:56px;border-radius:32px;background:linear-gradient(135deg,#160828 0%,#261447 50%,#4A2290 100%);color:#fff;display:flex;justify-content:space-between;align-items:center;gap:32px;position:relative;overflow:hidden}
.finalCta::after{content:"";position:absolute;top:-100px;right:-100px;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(255,122,26,.4),transparent 70%);filter:blur(40px)}
.finalCta > *{position:relative;z-index:1}
.finalCta h2{font-size:38px;font-weight:800;letter-spacing:-.03em;margin:0 0 12px;line-height:1.1}
.finalCta h2 em{font-style:normal;color:var(--orange)}
.finalCta p{margin:0;color:#D7CEE6;font-size:15px}

.landingFoot{padding:24px 32px;max-width:1280px;margin:0 auto;border-top:1px solid var(--line);display:flex;justify-content:space-between;font-size:12px;color:var(--muted);align-items:center}
.landingFoot a{font-weight:600}

/* =============== AUTH (Login/Signup/Onboarding) =============== */
.authShell{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;background:linear-gradient(135deg,#FFF9EF 0%,#FFF4E6 100%)}
.authForm{padding:64px 80px;display:flex;flex-direction:column;justify-content:center;max-width:560px;margin:0 auto;width:100%}
.authSide{position:relative;overflow:hidden;background:radial-gradient(circle at 30% 20%,rgba(255,122,26,.4),transparent 50%),linear-gradient(135deg,#160828 0%,#261447 60%,#4A2290 100%);color:#fff;padding:64px;display:flex;flex-direction:column;justify-content:space-between}
.authSide::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:36px 36px;mask-image:linear-gradient(to bottom,rgba(0,0,0,.7),transparent 90%)}
.authSide > *{position:relative;z-index:1}
.authSide .authQuote{font-size:32px;font-weight:800;letter-spacing:-.03em;line-height:1.2}
.authSide .authQuote em{font-style:normal;color:var(--orange)}
.authSocial{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:18px 0}
.authSocial .btn{height:44px;font-size:13px}
.authDivider{display:flex;align-items:center;gap:12px;margin:8px 0 18px;color:var(--muted);font-size:12px}
.authDivider::before,.authDivider::after{content:"";flex:1;height:1px;background:var(--line)}

/* Onboarding stepper */
.stepper{display:flex;align-items:center;gap:0;margin:0 0 32px}
.stepDot{flex:0;display:flex;align-items:center;gap:10px}
.stepCircle{width:32px;height:32px;border-radius:50%;background:var(--line);color:var(--muted);font-weight:800;display:grid;place-items:center;font-size:13px;flex-shrink:0}
.stepDot.active .stepCircle{background:var(--orange);color:#fff;box-shadow:0 6px 16px rgba(255,122,26,.32)}
.stepDot.done .stepCircle{background:var(--green);color:#fff}
.stepDot .stepLab{font-size:13px;font-weight:700;color:var(--muted);white-space:nowrap}
.stepDot.active .stepLab,.stepDot.done .stepLab{color:var(--purple)}
.stepLine{flex:1;height:2px;background:var(--line);margin:0 14px;min-width:30px}
.stepLine.done{background:var(--green)}

/* =============== PRODUCT / BRAND / CARDS =============== */
.brandTile{padding:14px;border-radius:16px;border:1px solid var(--line);background:#fff;display:flex;flex-direction:column;gap:10px;cursor:pointer;transition:.15s ease;position:relative;text-align:left}
.brandTile:hover{transform:translateY(-2px);box-shadow:var(--shadow2)}
.brandTile.active{border:2px solid var(--orange);background:var(--orange-soft);padding:13px}
.brandTile .bMark{width:58px;height:58px;border-radius:13px;display:grid;place-items:center;color:#fff;font-weight:800;font-size:18px;flex-shrink:0;box-shadow:var(--shadow3)}
.brandTile .bInfo{display:flex;gap:10px;align-items:center}
.brandTile .bInfo > div:not(.bMark){flex:1;min-width:0}
.brandTile b{font-size:14px;color:var(--purple);display:block;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.brandTile .bSub{font-size:11px;color:var(--muted)}
.brandTile.add{border:1.5px dashed var(--line3);background:transparent;align-items:center;justify-content:center;min-height:96px;color:var(--muted)}

.productCard{padding:10px;border-radius:14px;border:1px solid var(--line);background:#fff;cursor:pointer;transition:.15s ease;position:relative;text-align:left;display:flex;flex-direction:column;gap:8px}
.productCard:hover{transform:translateY(-2px);box-shadow:var(--shadow2)}
.productCard.active{border:2px solid var(--orange);padding:9px;box-shadow:0 0 0 4px rgba(255,122,26,.10)}
.productImg{aspect-ratio:1/1;border-radius:10px;background:linear-gradient(135deg,#FFEDD5,#FED7AA);position:relative;overflow:hidden;display:grid;place-items:center;color:#7C2D12;font-weight:800;letter-spacing:.05em;font-size:11px}
.productImg .pBlob1{position:absolute;top:8px;right:8px;width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.5)}
.productImg .pBlob2{position:absolute;bottom:-10px;left:-10px;width:60px;height:60px;border-radius:50%;background:rgba(249,115,22,.18)}
.productImg .pLabel{position:relative;z-index:1;background:linear-gradient(180deg,#FFFBEB,#FED7AA);padding:14px 6px;border-radius:8px;width:60%;text-align:center;box-shadow:0 4px 10px -2px rgba(124,45,18,.25)}
.productCard .pName{font-size:11.5px;font-weight:600;color:var(--ink);height:30px;overflow:hidden;line-height:1.3}
.productCard .pPrice{color:var(--orange);font-weight:800;font-size:13px}
.productCard .checkBadge{position:absolute;top:10px;right:10px;z-index:2;width:22px;height:22px;border-radius:99px;background:var(--orange);color:#fff;display:none;align-items:center;justify-content:center;font-size:11px;font-weight:900;box-shadow:var(--shadow3)}
.productCard.active .checkBadge{display:flex}
.ppProdView{margin-top:2px;width:100%;border:1px solid var(--line);background:#faf6ef;color:var(--purple);border-radius:8px;padding:5px 0;font-size:10.5px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;font-family:inherit;transition:.13s ease}
.ppProdView:hover{background:var(--orange-soft);color:var(--orange3);border-color:var(--orange)}

/* Voice / Archetype tiles */
.toneTile{padding:12px;border-radius:14px;border:1px solid var(--line);background:#fff;display:flex;gap:10px;cursor:pointer;text-align:left;transition:.15s;position:relative;align-items:flex-start}
.toneTile:hover{transform:translateY(-1px);box-shadow:var(--shadow3)}
.toneTile.active{border:2px solid var(--orange);background:var(--orange-soft);padding:11px}
.toneEmoji{width:34px;height:34px;border-radius:9px;background:var(--cream2);display:grid;place-items:center;font-size:17px;flex-shrink:0}
.toneTile.active .toneEmoji{background:#fff}
.toneTile .tInfo{flex:1;min-width:0}
.toneTile .tName{font-size:13px;font-weight:700;color:var(--purple);display:flex;gap:6px;align-items:baseline}
.toneTile .tSamp{font-size:11px;font-style:italic;color:var(--muted);margin-top:3px;line-height:1.45}

/* Topic card */
.topicCard{padding:16px;border-radius:16px;border:1px solid var(--line);background:#fff;cursor:pointer;transition:.15s;display:flex;flex-direction:column;gap:10px}
.topicCard:hover{transform:translateY(-2px);box-shadow:var(--shadow2)}
.topicCard .topicText{font-size:13.5px;font-weight:600;color:var(--ink);line-height:1.45;min-height:38px}
.topicCard.used{opacity:.55}

/* Tables */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl thead th{padding:12px 14px;text-align:left;background:var(--cream2);font-size:10px;font-weight:800;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;border-bottom:1px solid var(--line)}
.tbl thead th:first-child{border-radius:14px 0 0 0}
.tbl thead th:last-child{border-radius:0 14px 0 0}
.tbl tbody td{padding:14px;border-bottom:1px solid var(--line2);vertical-align:middle}
.tbl tbody tr:last-child td{border-bottom:0}
.tbl tbody tr:hover{background:var(--cream2)}

/* Calendar */
.calGrid{display:grid;grid-template-columns:repeat(7,1fr);border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff}
.calHead{padding:10px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);background:var(--cream2);border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.calHead:last-child{border-right:0}
.calDay{min-height:100px;padding:8px;border-right:1px solid var(--line2);border-bottom:1px solid var(--line2);cursor:pointer;transition:.15s;background:#fff;display:flex;flex-direction:column;gap:3px}
.calDay:nth-child(7n+7){border-right:0}
.calDay:hover{background:var(--cream2)}
.calDay.muted{background:#FAF6EE;color:var(--muted)}
.calDay.selected{background:var(--orange-soft);outline:2px solid var(--orange);outline-offset:-2px}
.calDay .dateNum{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:700;color:var(--ink);margin-bottom:2px}
.calDay.today .dateNum > span:first-child{background:var(--orange);color:#fff;width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-weight:800}
.calEvent{font-size:9.5px;font-weight:600;padding:2px 5px;border-radius:5px;background:rgba(24,119,242,.12);color:#1877F2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:3px}
.calEvent.ig{background:rgba(225,48,108,.12);color:#E1306C}
.calEvent.tt{background:rgba(15,23,42,.12);color:#0F172A}
.calEvent.hot{background:var(--orange);color:#fff}
.calEvent.draft{background:var(--purple-soft);color:var(--purple)}

/* Phone preview (for avatar/video) */
.phone{width:280px;aspect-ratio:9/16;border-radius:32px;background:linear-gradient(180deg,#FFEDD5 0%,#FED7AA 40%,#FB923C 100%);border:5px solid #111827;box-shadow:var(--shadow);position:relative;overflow:hidden;margin:0 auto}
.phoneHead{position:absolute;top:8px;left:14px;right:14px;display:flex;justify-content:space-between;font-size:11px;color:#fff;font-weight:700;z-index:3}
.phoneTitle{position:absolute;top:36px;left:16px;right:16px;background:#fff;border-radius:12px;padding:10px 12px;font-size:13px;font-weight:800;line-height:1.3;color:var(--purple);box-shadow:var(--shadow2);z-index:3}
.phoneFace{position:absolute;bottom:120px;left:50%;transform:translateX(-50%);width:110px;height:130px;border-radius:50% 50% 45% 45% / 60% 60% 40% 40%;background:linear-gradient(180deg,#FBCFB0,#F4A07A);box-shadow:inset 0 -10px 20px rgba(124,45,18,.15)}
.phoneFace::before{content:"";position:absolute;top:0;left:-8px;right:-8px;height:56px;background:#1F2937;border-radius:50% 50% 30% 30% / 90% 90% 30% 30%}
.phoneFace .eye{position:absolute;top:60px;width:12px;height:8px;background:#1F2937;border-radius:99px}
.phoneFace .eyeL{left:22px}.phoneFace .eyeR{right:22px}
.phoneFace .lips{position:absolute;top:88px;left:50%;transform:translateX(-50%);width:28px;height:14px;background:#9A1A47;border-radius:50%}
.phoneCaption{position:absolute;bottom:70px;left:16px;right:16px;background:rgba(0,0,0,.78);backdrop-filter:blur(6px);color:#fff;padding:8px 12px;border-radius:8px;font-size:12px;text-align:center;line-height:1.4;z-index:3}
.phoneCtrls{position:absolute;bottom:30px;left:16px;right:16px;z-index:3}
.phoneCtrls .pBar{height:3px;border-radius:99px;background:rgba(255,255,255,.35)}
.phoneCtrls .pBar > div{height:100%;background:#fff;width:38%;border-radius:99px}
.phoneCtrls .pTime{margin-top:6px;display:flex;justify-content:space-between;color:#fff;font-size:10px;font-weight:700}
.phonePlay{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.92);display:grid;place-items:center;color:var(--purple);box-shadow:0 8px 20px rgba(0,0,0,.30);z-index:4;font-size:22px}

/* Donut chart */
.donut{width:130px;height:130px;border-radius:50%;background:conic-gradient(var(--orange) 0 35%,var(--purple) 35% 65%,var(--blue) 65% 85%,#94A3B8 85%);position:relative;flex-shrink:0}
.donut::after{content:"";position:absolute;inset:18%;border-radius:50%;background:#fff}

/* Spark line container */
.sparkBox{height:36px;width:100px}

/* Misc */
.kbd{font-family:var(--mono);font-size:10px;background:var(--cream2);padding:1px 6px;border-radius:5px;border:1px solid var(--line)}
.scrollX{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px;scroll-snap-type:x mandatory}
.scrollX > *{scroll-snap-align:start;flex-shrink:0}

/* Toasts (page transition fade) */
.page{animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* Responsive */
@media(max-width:1280px){.sidebar{width:240px;flex-basis:240px}.search{width:240px}.heroH1{font-size:46px}.title{font-size:32px}}
@media(max-width:1024px){.g3,.g4,.g5,.g6{grid-template-columns:repeat(2,1fr)}.g12{grid-template-columns:1fr}.span3,.span4,.span5,.span6,.span7,.span8,.span9{grid-column:span 1}.heroH1{font-size:38px}.heroLogo{font-size:54px}.title{font-size:28px}.authShell{grid-template-columns:1fr}.authSide{display:none}.authForm{padding:36px 24px}}

/* Profile menu items — subtle hover so users know they're clickable */
.pmItem{transition:background .12s}
.pmItem:hover{background:var(--cream2)}

/* Mobile menu trigger (hamburger) — hidden on desktop, shown on mobile via media query below */
.mobileMenuBtn{display:none;width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:var(--surface);align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}
.mobileMenuBtn:active{background:var(--cream2)}
/* Backdrop overlay for the slide-out sidebar */
.mobileBackdrop{display:none;position:fixed;inset:0;background:rgba(15,8,30,.55);z-index:99;backdrop-filter:blur(4px);animation:fade .2s ease}

/* ── TABLET (≤820px) — what existed before, kept ── */
@media(max-width:820px){.app{flex-direction:column}.navScroll{max-height:300px}.search{width:100%;order:5}.g2{grid-template-columns:1fr}.hero{padding:32px 24px}.heroH1{font-size:32px}.finalCta{flex-direction:column;padding:32px;text-align:center}}

/* ── MOBILE (≤768px) — full handheld layout ── */
@media(max-width:768px){
  /* Sidebar becomes a slide-out drawer */
  .app{flex-direction:row;min-height:100vh}
  .sidebar{position:fixed;top:0;left:-100%;width:84vw;max-width:340px;height:100vh;z-index:100;transition:left .28s ease;box-shadow:0 0 60px rgba(0,0,0,.4);flex-basis:auto;overflow-y:auto}
  .sidebar.open{left:0}
  .mobileBackdrop.show{display:block}
  .mobileMenuBtn{display:inline-flex}
  /* Main area fills full width when sidebar is hidden */
  .main{padding:14px;width:100%}
  .mainInner{padding:0}
  /* Topbar — compact, breadcrumb truncates */
  .topbar{flex-wrap:wrap;gap:8px;padding:10px 0;margin-bottom:14px}
  .topbar .search{display:none}                          /* full-width search hidden on phone — saves space */
  .topbar .searchKbd{display:none}
  .breadcrumb{font-size:13px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .crumb-current{font-weight:700}
  .topRight{gap:6px}
  /* Cards: less padding so content fits the narrower frame */
  .card{padding:14px !important;border-radius:14px}
  .cardTitle{font-size:16px}
  .cardSub{font-size:12.5px}
  .eyebrow{font-size:10px}
  /* All grids collapse to single column (inline styles too) */
  .grid,
  div[style*="grid-template-columns"]:not(.calGrid):not(.authShell):not(.authSocial){
    grid-template-columns:1fr !important;
  }
  /* But keep small icon grids (≤4 small buttons) tight — common chip rows */
  .g4 > .pill, .g5 > .pill{min-width:0}
  /* Phone-preview iframe-ish element shouldn't dominate */
  .phone{max-width:280px;margin:0 auto}
  /* Touch-friendly buttons */
  .btn{min-height:40px;padding:0 14px}
  .btn.sm{min-height:34px}
  .pill{min-height:30px}
  /* Tabs scroll horizontally if too many */
  .tabs{overflow-x:auto;flex-wrap:nowrap;max-width:100%}
  .tabs .tab{flex-shrink:0}
  /* Tables become horizontally scrollable */
  table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
  /* Headings smaller */
  .title{font-size:22px}
  h1,h2,h3{line-height:1.3}
  /* Topbar credit/channel widgets — hide non-essential on tiny screens */
  .chWidget{display:none}
  /* Cloud sync pill — move to bottom-right but smaller */
  /* Hero text */
  .hero{padding:24px 16px}
  .heroH1{font-size:26px;line-height:1.25}
  /* Inputs full width */
  input.input,select.select,textarea.textarea{font-size:16px} /* 16px stops iOS Safari from zooming on focus */
  /* Toast bottom + center on mobile */
  /* Storyboard slot cards are already stacked — no change */
  /* Modal/dialog ovs (data-refclose etc.) — make them near-fullscreen */
  /* Any inline style="position:sticky" right column (phone preview pane) — unstick on mobile */
  div[style*="position:sticky"]{position:static !important}
}

/* ── PHONE (≤480px) — extra-compact ── */
@media(max-width:480px){
  .main{padding:10px}
  .card{padding:12px !important;border-radius:12px}
  .cardTitle{font-size:15px}
  .btn{padding:0 12px;font-size:12.5px}
  .btn.sm{font-size:11px}
  .breadcrumb{font-size:12px}
  .phone{max-width:240px}
  .heroH1{font-size:22px}
  /* Brand tile grid — 2 cols even on tiny phones (instead of 1) so they don't get huge */
  .grid.g2,.brandTiles{grid-template-columns:repeat(2,1fr) !important}
}
