:root{
  /* Warm ivory palette */
  --bg: #F5EFE6;
  --bg-deep: #EFE7D9;
  --surface: #FBF7F0;
  --surface-2: #F7F2E8;
  --ink: #2A2622;
  --ink-2: #3E3833;
  --muted: #7A706A;
  --muted-2: #A79E97;
  --line: #E4DCCE;
  --line-strong: #D4C8B4;

  /* Accent — warm terracotta */
  --accent: #B45F3F;
  --accent-soft: #E8C7B4;
  --accent-wash: #F4E3D4;
  --gold: #B8904A;

  /* Niche tags */
  --niche-fashion: #C28CA0;     /* dusty rose */
  --niche-fashion-bg: #F1E1E5;
  --niche-skincare: #8AA287;    /* sage */
  --niche-skincare-bg: #E3ECDF;
  --niche-wellness: #C49250;    /* warm amber */
  --niche-wellness-bg: #F2E3C9;
  --niche-fitness: #8BA3B8;     /* muted sky */
  --niche-fitness-bg: #DFE7EE;
  --niche-antiaging: #A593B5;   /* soft lavender */
  --niche-antiaging-bg: #E7DFEE;

  --radius: 14px;
  --radius-sm: 10px;
  --shadow-sm: 0 1px 2px rgba(60,40,20,0.04), 0 1px 0 rgba(60,40,20,0.02);
  --shadow-md: 0 2px 6px rgba(60,40,20,0.05), 0 6px 20px rgba(60,40,20,0.04);
  --shadow-lg: 0 6px 16px rgba(60,40,20,0.07), 0 20px 40px rgba(60,40,20,0.06);
  --serif: "DM Serif Display", Georgia, serif;
  --sans: "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;
  --mono: "DM Mono", ui-monospace, monospace;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:14px;-webkit-font-smoothing:antialiased;line-height:1.45}
body{min-height:100vh}

/* Typography */
.serif{font-family:var(--serif);font-weight:400;letter-spacing:-0.005em}
.mono{font-family:var(--mono);font-size:11px;letter-spacing:0.04em;text-transform:uppercase;color:var(--muted)}
h1,h2,h3,h4{margin:0;font-family:var(--serif);font-weight:400;letter-spacing:-0.015em;color:var(--ink)}
h1{font-size:40px;line-height:1.1}
h2{font-size:28px;line-height:1.15}
h3{font-size:20px;line-height:1.25}
p{margin:0;color:var(--ink-2)}
a{color:inherit}

button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;color:inherit;padding:0}

/* App frame */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.app.collapsed{grid-template-columns:72px 1fr}
.main{min-width:0;padding:40px 48px 120px;max-width:1440px;margin:0 auto;width:100%}

/* Sidebar */
.sidebar{background:var(--surface);border-right:1px solid var(--line);padding:24px 16px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:8px}
.brand{padding:8px 12px 20px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line);margin-bottom:12px}
.brand-mark{width:32px;height:32px;border-radius:50%;background:var(--ink);color:var(--bg);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:18px;flex-shrink:0}
.brand-name{font-family:var(--serif);font-size:18px;line-height:1;white-space:nowrap;overflow:hidden}
.brand-sub{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:0.1em;margin-top:3px;white-space:nowrap}

.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--ink-2);transition:background 120ms;cursor:pointer;text-align:left;width:100%;font-weight:500;font-size:13.5px}
.nav-item:hover{background:var(--surface-2)}
.nav-item.active{background:var(--ink);color:var(--bg)}
.nav-item.active .nav-count{background:rgba(255,255,255,0.15);color:var(--bg)}
.nav-ico{width:18px;height:18px;flex-shrink:0;opacity:0.9}
.nav-label{white-space:nowrap;overflow:hidden;flex:1}
.nav-count{margin-left:auto;font-size:11px;background:var(--surface-2);color:var(--muted);padding:2px 7px;border-radius:10px;font-weight:600}

.side-foot{margin-top:auto;padding:12px;border-top:1px solid var(--line);display:flex;gap:10px;align-items:center}
.avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-wash);color:var(--accent);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:14px;flex-shrink:0}

.collapsed .nav-label,.collapsed .nav-count,.collapsed .brand-name,.collapsed .brand-sub,.collapsed .side-foot .who{display:none}
.collapsed .brand{justify-content:center;padding:8px 0 20px}
.collapsed .nav-item{justify-content:center;padding:10px}

/* Header */
.pagehead{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:32px;padding-bottom:20px;border-bottom:1px solid var(--line)}
.pagehead .eyebrow{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:0.12em;margin-bottom:10px}
.pagehead h1{font-size:42px}
.pagehead .sub{color:var(--muted);margin-top:6px;max-width:520px}
.pagehead-actions{display:flex;gap:8px;flex-shrink:0}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border-radius:10px;font-size:13px;font-weight:500;transition:all 120ms;border:1px solid transparent;white-space:nowrap}
.btn-primary{background:var(--ink);color:var(--bg)}
.btn-primary:hover{background:var(--ink-2)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-strong)}
.btn-ghost:hover{background:var(--surface)}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:#A3553A}
.btn-sm{padding:6px 10px;font-size:12px}

/* Cards */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.card-lift:hover{box-shadow:var(--shadow-md);transform:translateY(-1px);transition:all 160ms}
.card-pad{padding:20px}
.card-pad-lg{padding:28px}

/* Niche tags */
.tag{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:500;letter-spacing:0.02em;white-space:nowrap}
.tag::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;opacity:0.9}
.tag-fashion{background:var(--niche-fashion-bg);color:var(--niche-fashion)}
.tag-skincare{background:var(--niche-skincare-bg);color:var(--niche-skincare)}
.tag-wellness{background:var(--niche-wellness-bg);color:var(--niche-wellness)}
.tag-fitness{background:var(--niche-fitness-bg);color:var(--niche-fitness)}
.tag-antiaging{background:var(--niche-antiaging-bg);color:var(--niche-antiaging)}

/* Status pills */
.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border-radius:6px;font-size:11px;font-weight:500;border:1px solid var(--line)}
.pill-draft{background:var(--surface-2);color:var(--muted);border-color:var(--line)}
.pill-ready{background:#FBF0D9;color:#9A7224;border-color:#F1E2C2}
.pill-approved{background:#E3ECDF;color:#5E7A5A;border-color:#CEDCC8}
.pill-live{background:var(--ink);color:var(--bg);border-color:var(--ink)}

/* Format badge */
.fmt{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted);padding:2px 0}

/* Dashboard grid */
.dash-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px}
.dash-grid-2{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}

/* ICP Card */
.icp{background:linear-gradient(180deg,#FBF7F0 0%,#F4E3D4 100%);border:1px solid var(--line-strong);border-radius:18px;padding:32px;position:relative;overflow:hidden}
.icp::before{content:"ICP";position:absolute;top:20px;right:28px;font-family:var(--serif);font-style:italic;font-size:64px;color:var(--accent-soft);opacity:0.4;line-height:1}
.icp-pin{position:absolute;top:18px;left:18px;display:inline-flex;align-items:center;gap:6px;background:var(--ink);color:var(--bg);padding:4px 10px;border-radius:999px;font-size:10px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase}
.icp-content{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:40px;position:relative;z-index:1}
.icp h3{font-size:13px;font-family:var(--sans);font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted);margin-bottom:12px}
.icp .big{font-family:var(--serif);font-size:22px;line-height:1.3;color:var(--ink);margin-bottom:8px}
.icp .p{color:var(--ink-2);font-size:13.5px;line-height:1.55}

/* Stat card */
.stat{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:20px}
.stat-n{font-family:var(--serif);font-size:36px;line-height:1;color:var(--ink);margin:4px 0 8px}
.stat-l{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:0.08em;font-weight:500}
.stat-s{color:var(--ink-2);font-size:12.5px;margin-top:8px;padding-top:12px;border-top:1px solid var(--line)}

/* Week planner */
.week{margin-bottom:28px}
.week-head{display:flex;align-items:center;justify-content:space-between;padding:16px 0;margin-bottom:14px;border-bottom:1px solid var(--line)}
.week-title{display:flex;align-items:baseline;gap:14px}
.week-title .num{font-family:var(--serif);font-style:italic;font-size:32px;color:var(--accent);line-height:1}
.week-title h3{font-size:22px}
.week-title .sub{color:var(--muted);font-size:12px;margin-left:4px}
.week-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:14px}
.slot-head{font-size:10px;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted);margin-bottom:8px;font-weight:600}

.content-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px;cursor:pointer;transition:all 160ms;display:flex;flex-direction:column;gap:10px;min-height:150px;position:relative}
.content-card:hover{border-color:var(--line-strong);box-shadow:var(--shadow-md);transform:translateY(-1px)}
.content-card.empty{border:1.5px dashed var(--line-strong);background:transparent;color:var(--muted);align-items:center;justify-content:center;font-size:13px;text-align:center}
.content-card.empty:hover{border-color:var(--accent);color:var(--accent)}
.content-card .topic{font-family:var(--serif);font-size:17px;line-height:1.2;color:var(--ink);margin-top:auto}
.content-card .row{display:flex;align-items:center;justify-content:space-between;gap:8px}

/* Detail drawer */
.drawer-veil{position:fixed;inset:0;background:rgba(40,30,20,0.35);z-index:80;animation:fade 140ms}
.drawer{position:fixed;top:0;right:0;height:100vh;width:min(640px,100vw);background:var(--bg);z-index:90;overflow-y:auto;box-shadow:-20px 0 60px rgba(40,30,20,0.14);animation:slide 180ms}
.drawer-head{padding:28px 32px 20px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--bg);z-index:2}
.drawer-body{padding:24px 32px 80px;display:flex;flex-direction:column;gap:22px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:11px;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted);font-weight:600}
.input,.textarea,select.input{border:1px solid var(--line);background:var(--surface);border-radius:10px;padding:10px 12px;font-family:var(--sans);font-size:13.5px;color:var(--ink);outline:none;transition:border-color 120ms;width:100%}
.input:focus,.textarea:focus,select.input:focus{border-color:var(--accent);background:#fff}
.textarea{min-height:68px;resize:vertical;line-height:1.5}

@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes slide{from{transform:translateX(24px);opacity:0}to{transform:translateX(0);opacity:1}}

/* Hook chips */
.hooks{display:flex;flex-direction:column;gap:8px}
.hook{border:1px solid var(--line);border-radius:10px;padding:12px 14px;background:var(--surface);transition:all 140ms;display:flex;gap:12px;align-items:flex-start}
.hook:hover{border-color:var(--line-strong)}
.hook textarea.hook-txt{width:100%;flex:1}
.hook textarea.hook-txt::placeholder{color:var(--muted-2)}

/* Card delete handle */
.card-del{position:absolute;top:8px;right:8px;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--muted-2);background:rgba(255,255,255,0);opacity:0;transition:opacity 120ms,background 120ms}
.content-card:hover .card-del,.kcard:hover .card-del,.bl:hover .card-del{opacity:1}
.bl .card-del{top:12px;right:38px}
.card-del:hover{background:var(--bg-deep);color:var(--accent)}
.hook.sel{border-color:var(--accent);background:var(--accent-wash)}
.hook-cat{font-size:10px;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted);font-weight:600;min-width:82px;margin-top:2px}
.hook.sel .hook-cat{color:var(--accent)}
.hook-txt{flex:1;font-size:13.5px;color:var(--ink);line-height:1.4}

.checklist{display:flex;flex-direction:column;gap:6px}
.check{display:flex;gap:10px;align-items:center;padding:8px 10px;border-radius:8px;cursor:pointer;transition:background 100ms}
.check:hover{background:var(--surface-2)}
.check input{accent-color:var(--accent);width:15px;height:15px;cursor:pointer;flex-shrink:0}
.check span{font-size:13px;color:var(--ink-2)}
.check.done span{text-decoration:line-through;color:var(--muted)}

/* Approval badge */
.appr{display:flex;gap:10px;align-items:center;padding:12px 16px;border-radius:12px;background:var(--surface);border:1px solid var(--line)}
.appr.ok{background:#E3ECDF;border-color:#CEDCC8;color:#4A6847}
.appr-switch{margin-left:auto;display:inline-flex;background:var(--surface-2);border-radius:999px;padding:3px;font-size:11px;font-weight:600}
.appr-switch button{padding:5px 11px;border-radius:999px;color:var(--muted)}
.appr-switch button.on{background:var(--ink);color:var(--bg)}
.appr.ok .appr-switch button.on{background:#4A6847}

/* Kanban */
.kanban{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;overflow-x:auto;padding-bottom:8px}
.kanban.scroll{grid-template-columns:repeat(7,minmax(240px,1fr));overflow-x:auto}
.klane{background:var(--surface-2);border:1px solid var(--line);border-radius:14px;padding:14px;min-height:300px;display:flex;flex-direction:column;gap:10px}
.klane-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px;padding:2px 4px}
.klane-head .t{font-size:11px;text-transform:uppercase;letter-spacing:0.1em;color:var(--ink-2);font-weight:700}
.klane-head .n{background:var(--surface);border:1px solid var(--line);padding:1px 8px;border-radius:999px;font-size:11px;color:var(--muted);font-weight:600}
.kcard{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:12px;cursor:grab;transition:all 120ms;display:flex;flex-direction:column;gap:8px}
.kcard:hover{box-shadow:var(--shadow-sm);border-color:var(--line-strong)}
.kcard:active{cursor:grabbing}
.kcard.drag{opacity:0.4}
.kcard .t{font-family:var(--serif);font-size:15px;line-height:1.25;color:var(--ink)}
.kcard .meta{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:6px}

/* Funnel diagram */
.funnel{background:linear-gradient(180deg,var(--surface) 0%,var(--surface-2) 100%);border:1px solid var(--line);border-radius:18px;padding:36px 32px;display:flex;flex-direction:column;align-items:center;gap:12px}
.fnode{background:var(--surface);border:1px solid var(--line-strong);border-radius:14px;padding:18px 22px;width:min(520px,100%);display:flex;gap:16px;align-items:center;box-shadow:var(--shadow-sm);position:relative}
.fnode.hi{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.fnode.hi .f-sub{color:rgba(255,255,255,0.6)}
.fnode.acc{background:var(--accent-wash);border-color:var(--accent-soft)}
.fnode .ico{width:42px;height:42px;border-radius:10px;background:var(--bg-deep);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fnode.hi .ico{background:rgba(255,255,255,0.08)}
.fnode.acc .ico{background:var(--accent-soft)}
.fnode .ftxt{flex:1}
.fnode .ft{font-family:var(--serif);font-size:18px;line-height:1.2}
.fnode .f-sub{font-size:12px;color:var(--muted);margin-top:3px}
.farrow{width:2px;height:28px;background:var(--line-strong);position:relative}
.farrow::after{content:"";position:absolute;left:-4px;bottom:-2px;width:10px;height:10px;border-right:2px solid var(--line-strong);border-bottom:2px solid var(--line-strong);transform:rotate(45deg)}

/* Media kit tracker */
.mediakit{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:22px;display:grid;grid-template-columns:1.2fr 1.8fr;gap:28px;align-items:center}
.mk-ring{display:flex;align-items:center;gap:18px}
.ring{width:88px;height:88px;position:relative}
.ring svg{transform:rotate(-90deg)}
.ring circle{fill:none;stroke-width:8}
.ring .bg{stroke:var(--line)}
.ring .fg{stroke:var(--accent);transition:stroke-dashoffset 300ms}
.ring-n{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:22px}

/* Revenue cards */
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rev{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:26px;display:flex;flex-direction:column;gap:16px;min-height:340px}
.rev.locked{background:var(--surface-2);color:var(--muted)}
.rev.locked .serif{color:var(--muted-2)}
.rev-head{display:flex;justify-content:space-between;align-items:flex-start}
.mini-bar{display:flex;align-items:flex-end;gap:6px;height:60px}
.mini-bar .b{flex:1;background:var(--accent-soft);border-radius:4px 4px 0 0;position:relative}
.mini-bar .b.hi{background:var(--accent)}

/* Backlog */
.backlog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.bl{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:18px;display:flex;flex-direction:column;gap:10px;position:relative;transition:all 140ms}
.bl:hover{box-shadow:var(--shadow-md);border-color:var(--line-strong);transform:translateY(-1px)}
.bl .star{position:absolute;top:14px;right:14px;font-size:14px;color:var(--gold)}

/* Mobile */
.mobile-tab{display:none}
@media (max-width: 900px){
  .app{grid-template-columns:1fr}
  .sidebar{display:none}
  .main{padding:24px 18px 120px}
  h1{font-size:30px}
  .pagehead{flex-direction:column;align-items:flex-start;gap:12px}
  .pagehead-actions{flex-wrap:wrap}
  .dash-grid,.dash-grid-2{grid-template-columns:1fr}
  .icp-content{grid-template-columns:1fr;gap:20px}
  .week-grid{grid-template-columns:1fr}
  .rev-grid{grid-template-columns:1fr}
  .mediakit{grid-template-columns:1fr}
  .drawer{width:100vw}
  .mobile-tab{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--line);padding:8px 6px calc(8px + env(safe-area-inset-bottom));z-index:50;justify-content:space-around}
  .mobile-tab button{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;border-radius:10px;color:var(--muted);font-size:10px;font-weight:600}
  .mobile-tab button.active{color:var(--ink);background:var(--surface-2)}
  .mobile-tab svg{width:20px;height:20px}
}

/* View toggle */
.view-toggle{display:inline-flex;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:3px;gap:2px}
.view-toggle button{padding:6px 14px;border-radius:7px;font-size:12.5px;font-weight:500;color:var(--muted);transition:all 120ms}
.view-toggle button.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}

/* Schedule view */
.schedule-view{display:flex;flex-direction:column}
.sched-empty{display:flex;flex-direction:column;align-items:center;gap:16px;padding:80px 0;color:var(--muted);text-align:center}
.sched-empty-icon{font-size:2.5rem}
.sched-week{border-bottom:1px solid var(--line)}
.sched-week-head{display:flex;align-items:center;gap:14px;padding:14px 8px;cursor:pointer;border-radius:10px;transition:background 100ms;user-select:none}
.sched-week-head:hover{background:var(--surface-2)}
.sched-week-num{font-style:italic;font-size:22px;color:var(--accent);width:32px;text-align:right;flex-shrink:0;line-height:1}
.sched-week-info{flex:1}
.sched-week-label{font-weight:600;font-size:14px;color:var(--ink)}
.sched-week-meta{font-size:11.5px;color:var(--muted);margin-top:2px}
.sched-week-dots{display:flex;gap:6px;align-items:center;margin-right:8px}
.sched-dot{width:9px;height:9px;border-radius:50%;background:var(--line-strong);transition:background 120ms}
.sched-dot.filled{background:var(--accent-soft)}
.sched-dot.approved{background:var(--accent)}
.sched-slots{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding:4px 8px 18px 54px}
.sched-slot-label{font-size:10px;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted);margin-bottom:6px;font-weight:600}
.sched-card{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:14px;cursor:pointer;display:flex;flex-direction:column;gap:8px;transition:all 140ms;position:relative;min-height:110px}
.sched-card:hover{border-color:var(--line-strong);box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.sched-card-top{display:flex;align-items:center;justify-content:space-between;gap:6px}
.sched-card-topic{font-family:var(--serif);font-size:14px;line-height:1.3;color:var(--ink);margin-top:auto}
.sched-card-foot{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.sched-approved-mark{font-size:10px;font-weight:600;color:#5E7A5A;letter-spacing:0.04em}
.sched-add{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;border:1.5px dashed var(--line-strong);border-radius:10px;padding:14px;color:var(--muted);font-size:12px;min-height:110px;width:100%;transition:all 120ms;cursor:pointer;background:transparent}
.sched-add:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-wash)}
.sched-add-week{display:flex;align-items:center;gap:8px;margin:18px 0 0 8px;padding:10px 16px;border-radius:10px;border:1.5px dashed var(--line-strong);color:var(--muted);font-size:13px;cursor:pointer;background:transparent;transition:all 120ms;width:fit-content}
.sched-add-week:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-wash)}

/* Calendar view */
.cal-view{display:flex;flex-direction:column;gap:20px}
.cal-nav{display:flex;align-items:center;gap:12px}
.cal-month-label{font-family:var(--serif);font-size:22px;color:var(--ink);min-width:220px}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:auto repeat(6,minmax(96px,auto));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.cal-weekday{background:var(--surface-2);padding:10px 4px;font-size:10px;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted);font-weight:600;text-align:center}
.cal-day{background:var(--surface);padding:8px 6px 10px;display:flex;flex-direction:column;gap:3px}
.cal-day.other-month{background:var(--bg-deep)}
.cal-day.other-month .cal-day-num{color:var(--muted-2)}
.cal-day-num{font-size:11px;font-weight:600;color:var(--ink-2);margin-bottom:3px;line-height:1}
.cal-today-badge{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:var(--ink);color:var(--bg);font-size:10.5px;font-weight:700}
.cal-chip{display:flex;align-items:center;gap:3px;padding:3px 6px;border-radius:5px;background:var(--surface-2);border:1px solid var(--line);cursor:pointer;transition:all 100ms;overflow:hidden}
.cal-chip:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.cal-chip-fmt{font-size:8px;flex-shrink:0;opacity:0.6}
.cal-chip-topic{font-size:10px;color:var(--ink);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cal-chip-ok{font-size:8px;color:#5E7A5A;margin-left:auto;flex-shrink:0}
.cal-chip.niche-fashion{background:var(--niche-fashion-bg);border-color:var(--niche-fashion)}.cal-chip.niche-fashion .cal-chip-topic{color:var(--niche-fashion)}
.cal-chip.niche-skincare{background:var(--niche-skincare-bg);border-color:var(--niche-skincare)}.cal-chip.niche-skincare .cal-chip-topic{color:var(--niche-skincare)}
.cal-chip.niche-wellness{background:var(--niche-wellness-bg);border-color:var(--niche-wellness)}.cal-chip.niche-wellness .cal-chip-topic{color:var(--niche-wellness)}
.cal-chip.niche-fitness{background:var(--niche-fitness-bg);border-color:var(--niche-fitness)}.cal-chip.niche-fitness .cal-chip-topic{color:var(--niche-fitness)}
.cal-chip.niche-antiaging{background:var(--niche-antiaging-bg);border-color:var(--niche-antiaging)}.cal-chip.niche-antiaging .cal-chip-topic{color:var(--niche-antiaging)}
.cal-legend{display:flex;gap:8px;flex-wrap:wrap;padding-top:4px}
.cal-legend-item{display:flex;align-items:center}

/* Dashboard */
.dash-sections{display:flex;flex-direction:column;gap:32px}
.dash-section{}
.dash-section-head{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.dash-section-head h3{font-size:20px}
.dash-section-meta{font-size:11px;color:var(--muted);font-family:var(--mono);letter-spacing:0.04em}
.dash-empty{color:var(--muted);font-size:13.5px;padding:20px 0;line-height:1.6}
.inline-link{color:var(--accent);background:none;border:none;font-size:inherit;font-family:inherit;cursor:pointer;padding:0}
.inline-link:hover{text-decoration:underline}
.dash-list{display:flex;flex-direction:column;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.dash-item{background:var(--surface);display:flex;align-items:center;gap:16px;padding:14px 18px;cursor:pointer;transition:background 100ms}
.dash-item:hover{background:var(--surface-2)}
.dash-item-date{font-family:var(--mono);font-size:10px;color:var(--muted);min-width:48px;flex-shrink:0}
.dash-item-body{flex:1;min-width:0}
.dash-item-title{font-weight:500;font-size:14px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Pipeline */
.pipe-kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;align-items:start}
.pipe-lane{background:var(--surface-2);border:1px solid var(--line);border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:10px}
.pipe-lane-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.pipe-lane-title{font-size:11px;text-transform:uppercase;letter-spacing:0.1em;color:var(--ink-2);font-weight:700}
.pipe-lane-count{background:var(--surface);border:1px solid var(--line);padding:1px 8px;border-radius:999px;font-size:11px;color:var(--muted);font-weight:600}
.pipe-card{background:var(--surface);border:1px solid var(--line);border-radius:10px;overflow:hidden;transition:box-shadow 120ms}
.pipe-card:hover{box-shadow:var(--shadow-sm)}
.pipe-card-body{padding:12px 14px;cursor:pointer}
.pipe-card-title{font-family:var(--serif);font-size:14px;line-height:1.3;color:var(--ink);margin-top:6px}
.pipe-date-badge{display:inline-flex;align-items:center;gap:4px;background:var(--accent-wash);color:var(--accent);border-radius:6px;padding:2px 8px;font-size:10px;font-weight:600;margin-top:6px}
.pipe-card-moves{display:flex;border-top:1px solid var(--line)}
.pipe-move-btn{flex:1;padding:7px;font-size:14px;color:var(--muted);background:transparent;border:none;cursor:pointer;transition:all 100ms;line-height:1}
.pipe-move-btn:hover:not(:disabled){background:var(--surface-2);color:var(--ink)}
.pipe-move-btn:disabled{opacity:0.2;cursor:default}
.pipe-add-btn{display:flex;align-items:center;justify-content:center;gap:6px;border:1.5px dashed var(--line-strong);border-radius:8px;padding:8px;color:var(--muted);font-size:12px;cursor:pointer;background:transparent;transition:all 120ms;width:100%}
.pipe-add-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-wash)}

/* Stage pills in drawer */
.stage-pills{display:flex;gap:6px;flex-wrap:wrap}
.stage-pill{padding:6px 14px;border-radius:999px;border:1.5px solid var(--line);font-size:12px;font-weight:500;color:var(--muted);cursor:pointer;transition:all 120ms;background:transparent;white-space:nowrap}
.stage-pill.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.stage-pill:hover:not(.active){border-color:var(--line-strong);color:var(--ink)}

/* Quick add modal */
.quick-add-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg);border:1px solid var(--line);border-radius:16px;padding:28px;width:min(400px,90vw);z-index:91;box-shadow:var(--shadow-lg)}

/* Brand cards */
.brand-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.brand-card{cursor:pointer;transition:all 140ms}
.brand-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.brand-card-name{font-size:18px}

/* Ideas */
.ideas-add-row{display:flex;gap:10px;margin-bottom:28px}
.ideas-add-row .input{flex:1}
.ideas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.idea-card{padding:18px;cursor:pointer;transition:all 140ms;position:relative;display:flex;flex-direction:column;gap:10px}
.idea-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.idea-title{font-family:var(--serif);font-size:16px;line-height:1.35;color:var(--ink)}

/* Mobile overrides */
@media(max-width:900px){
  .pipe-kanban{grid-template-columns:1fr}
  .dash-item-date{display:none}

  /* Calendar mobile */
  .cal-view{gap:12px}
  .cal-nav{flex-wrap:wrap;gap:8px}
  .cal-month-label{min-width:0;font-size:17px;flex:1}
  .cal-grid{border-radius:10px;grid-template-rows:auto repeat(6,1fr)}
  .cal-weekday{padding:6px 2px;font-size:8px;letter-spacing:0.04em}
  .cal-day{aspect-ratio:1;padding:3px 2px;overflow:hidden;gap:2px}
  .cal-day-num{font-size:10px;margin-bottom:1px}
  .cal-today-badge{width:16px;height:16px;font-size:9px}
  .cal-chip{width:6px;height:6px;min-width:6px;border-radius:50%;padding:0;flex-shrink:0}
  .cal-chip-topic,.cal-chip-fmt,.cal-chip-ok{display:none}
  .cal-legend{display:none}
}

/* Utility */
.row-sb{display:flex;align-items:center;justify-content:space-between;gap:10px}
.col{display:flex;flex-direction:column}
.gap-xs{gap:6px}.gap-sm{gap:10px}.gap-md{gap:14px}.gap-lg{gap:20px}.gap-xl{gap:28px}
.flex{display:flex}.wrap{flex-wrap:wrap}.ai-c{align-items:center}.jc-sb{justify-content:space-between}
.mut{color:var(--muted)}
.hidden{display:none}
.divider{height:1px;background:var(--line);border:none;margin:0}
hr.dashed{border:0;border-top:1px dashed var(--line);margin:0}
