*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f5f4f0;
  --surface:rgba(0,0,0,0.03);
  --surface2:rgba(0,0,0,0.06);
  --surface3:rgba(0,0,0,0.09);
  --border:rgba(0,0,0,0.08);
  --border2:rgba(0,0,0,0.14);
  --text:#0f0e0c;
  --text2:#6b6860;
  --text3:#aba8a0;
  --green:#e85a0a;
  --green-glow:rgba(232,90,10,0.3);
  --green-light:rgba(232,90,10,0.08);
  --green-dark:#7a2800;
  --accent:#e85a0a;
  --accent2:#ff7a30;
  --accent-glow:rgba(232,90,10,0.4);
  --accent-dim:rgba(232,90,10,0.08);
  --amber:#d48800;
  --red:#d94040;
  --blue:#2a6ccc;
  --purple:#7a50cc;
  --pink:#c04880;
  --glass:rgba(255,255,255,0.7);
  --glass-border:rgba(0,0,0,0.08);
  --card-bg:#ffffff;
  --radius:12px;
  --radius-sm:8px;
  --shadow:0 4px 24px rgba(0,0,0,0.08),0 1px 4px rgba(0,0,0,0.06);
  --shadow-sm:0 2px 12px rgba(0,0,0,0.06);
  --grad-primary:linear-gradient(135deg,#e85a0a 0%,#c83000 100%);
  --grad-orange:linear-gradient(135deg,#e85a0a 0%,#c83000 100%);
  --grad-purple:linear-gradient(135deg,#7a50cc 0%,#b030c0 100%);
  --grad-blue:linear-gradient(135deg,#2a6ccc 0%,#1a44a0 100%);
  --grad-green:linear-gradient(135deg,#e85a0a 0%,#0fa8a8 100%);
  --grad-pink:linear-gradient(135deg,#c04880 0%,#902ad0 100%);
}
body{font-family:'Inter',sans-serif;background:#f0ede8;color:var(--text);min-height:100vh;display:flex;flex-direction:column;position:relative;overflow-x:hidden}

/* Animated mesh gradient blobs */
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(ellipse 60% 55% at var(--bx1,18%) var(--by1,20%), rgba(232,90,10,0.32) 0%,transparent 70%),
    radial-gradient(ellipse 55% 50% at var(--bx2,78%) var(--by2,15%), rgba(255,180,120,0.22) 0%,transparent 65%),
    radial-gradient(ellipse 50% 60% at var(--bx3,12%) var(--by3,75%), rgba(42,80,200,0.22) 0%,transparent 65%),
    radial-gradient(ellipse 45% 45% at var(--bx4,85%) var(--by4,80%), rgba(120,60,200,0.12) 0%,transparent 60%),
    radial-gradient(ellipse 70% 40% at 50% 50%, rgba(255,255,255,0.55) 0%,transparent 80%),
    #f0ede8;
  animation:mesh-drift 18s ease-in-out infinite alternate}
@keyframes mesh-drift{
  0%  {--bx1:18%;--by1:20%;--bx2:78%;--by2:15%;--bx3:12%;--by3:75%;--bx4:85%;--by4:80%}
  25% {--bx1:25%;--by1:30%;--bx2:70%;--by2:25%;--bx3:20%;--by3:65%;--bx4:78%;--by4:72%}
  50% {--bx1:15%;--by1:15%;--bx2:82%;--by2:10%;--bx3:8%; --by3:82%;--bx4:88%;--by4:85%}
  75% {--bx1:22%;--by1:28%;--bx2:75%;--by2:20%;--bx3:15%;--by3:70%;--bx4:80%;--by4:78%}
  100%{--bx1:18%;--by1:22%;--bx2:80%;--by2:18%;--bx3:10%;--by3:78%;--bx4:83%;--by4:82%}}
.shell{position:relative;z-index:1}
a{color:var(--accent);text-decoration:none}

/* TOP NAV */
.shell{display:flex;flex-direction:column;min-height:100vh}
.topnav{display:flex;align-items:center;padding:0 64px;height:68px;background:rgba(245,244,240,0.85);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid rgba(0,0,0,0.07);position:fixed;top:0;left:0;right:0;z-index:100;transition:background .3s ease}
.topnav-logo{display:flex;align-items:center;gap:10px;margin-right:56px;flex-shrink:0}
.logo-dot{width:9px;height:9px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px rgba(232,90,10,0.7),0 0 20px rgba(232,90,10,0.4);animation:pulse-dot 3s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 10px rgba(232,90,10,0.7),0 0 20px rgba(232,90,10,0.35)}50%{box-shadow:0 0 18px rgba(232,90,10,0.9),0 0 36px rgba(232,90,10,0.5)}}
.logo-name{font-size:15px;font-weight:700;color:var(--text);letter-spacing:-0.4px}
.topnav-links{display:flex;align-items:center;gap:2px;flex:1}
.nav-item{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;cursor:pointer;font-size:14px;color:rgba(15,14,12,0.45);transition:color .2s ease;border:none;background:none;font-family:'Inter',sans-serif;font-weight:500;white-space:nowrap;position:relative;letter-spacing:-0.1px}
.nav-item:hover{color:rgba(15,14,12,0.8)}
.nav-item.active{color:var(--text)}
.nav-item.active::after{content:'';position:absolute;bottom:-1px;left:18px;right:18px;height:1.5px;background:var(--accent);border-radius:2px 2px 0 0;box-shadow:0 0 8px rgba(232,90,10,0.6)}
.nav-badge{background:var(--accent);color:#fff;font-size:9px;font-weight:700;padding:1px 5px;border-radius:6px;min-width:16px;text-align:center;margin-left:2px}
.topnav-actions{display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0}
/* SETTINGS GEAR DROPDOWN */
.settings-menu-wrap{position:relative}
.settings-gear-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:rgba(0,0,0,0.05);border:1px solid rgba(0,0,0,0.09);color:var(--text2);cursor:pointer;transition:all .2s;padding:0}
.settings-gear-btn:hover{background:rgba(0,0,0,0.09);color:var(--text);transform:rotate(30deg)}
.settings-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:180px;background:rgba(255,255,255,0.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(0,0,0,0.1);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,0.12);padding:6px;z-index:300;display:none;animation:dropdown-in .18s cubic-bezier(0.22,1,0.36,1) both}
.settings-dropdown.open{display:block}
@keyframes dropdown-in{from{opacity:0;transform:translateY(-6px) scale(0.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.settings-drop-item{display:block;width:100%;text-align:left;padding:8px 12px;font-size:13px;font-family:'Inter',sans-serif;font-weight:500;color:var(--text2);background:none;border:none;border-radius:8px;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}
.settings-drop-item:hover{background:rgba(0,0,0,0.06);color:var(--text)}
.settings-drop-sep{height:1px;background:rgba(0,0,0,0.08);margin:4px 0}
.settings-drop-item-notif{display:flex;align-items:center;gap:8px;padding:4px 12px}
.settings-drop-item-btn{background:none;border:none;font-size:13px;font-family:'Inter',sans-serif;font-weight:500;color:var(--text2);cursor:pointer;padding:4px 0;transition:color .15s}
.settings-drop-item-btn:hover{color:var(--text)}
.topnav-divider{width:1px;height:18px;background:rgba(0,0,0,0.1);margin:0 4px}
.topnav-ghost-btn{background:none;border:none;font-size:11px;color:var(--text3);cursor:pointer;padding:3px 6px;border-radius:4px;font-family:'Inter',sans-serif;transition:color .15s}
.topnav-ghost-btn:hover{color:var(--text2)}
.ch-dot-row{display:flex;align-items:center;gap:4px}
.ch-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.social-icon-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;color:rgba(15,14,12,0.35);transition:all .15s;text-decoration:none}
.social-icon-btn:hover{color:rgba(15,14,12,0.75)}

/* PAGE HERO */
.page-hero{padding:110px 64px 44px;position:relative;overflow:hidden;display:flex;align-items:flex-end}
.page-hero::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:900px;height:500px;background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(232,90,10,0.07) 0%,transparent 70%);pointer-events:none;z-index:0}
.page-hero-inner{position:relative;z-index:1;max-width:900px}
.page-hero-title{font-size:clamp(48px,7vw,88px);font-weight:700;color:var(--text);letter-spacing:-3px;line-height:0.95;margin-bottom:20px;animation:hero-in 0.9s cubic-bezier(0.22,1,0.36,1) both}
.page-hero-sub{font-size:18px;color:var(--text2);font-weight:400;letter-spacing:-0.2px;line-height:1.6;max-width:460px;animation:hero-in 0.9s 0.1s cubic-bezier(0.22,1,0.36,1) both}
@keyframes hero-in{from{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}
.page-hero-notif{position:absolute;top:84px;right:64px;display:flex;flex-direction:column;align-items:flex-end;gap:4px;z-index:1}
.topnav-date{font-size:32px;font-weight:700;color:var(--text);letter-spacing:-1px;line-height:1.1}
.topnav-series{font-size:20px;font-weight:700;color:var(--accent);letter-spacing:-0.3px;white-space:nowrap}

/* GLASS BUBBLE NAV */
.hero-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:28px;animation:hero-in 0.9s 0.2s cubic-bezier(0.22,1,0.36,1) both}
.hero-nav-btn{display:inline-flex;align-items:center;gap:6px;padding:11px 24px;border-radius:50px;font-size:14px;font-weight:500;font-family:'Inter',sans-serif;cursor:pointer;transition:all .22s cubic-bezier(.4,0,.2,1);position:relative;border:1px solid rgba(0,0,0,0.1);background:rgba(255,255,255,0.55);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);color:var(--text2);box-shadow:0 2px 12px rgba(0,0,0,0.07),inset 0 1px 0 rgba(255,255,255,0.8),inset 0 -1px 0 rgba(0,0,0,0.06);letter-spacing:-0.1px;white-space:nowrap}
.hero-nav-btn:hover{background:rgba(255,255,255,0.8);color:var(--text);box-shadow:0 4px 20px rgba(0,0,0,0.1),inset 0 1px 0 rgba(255,255,255,0.9),inset 0 -1px 0 rgba(0,0,0,0.06);transform:translateY(-1px)}
.hero-nav-btn.active{background:var(--grad-primary);border-color:transparent;color:#fff;box-shadow:0 4px 20px rgba(232,90,10,0.45),0 1px 3px rgba(232,90,10,0.3),inset 0 1px 0 rgba(255,200,150,0.4),inset 0 -1px 0 rgba(180,40,0,0.3);transform:translateY(0)}
.hero-nav-btn.active:hover{box-shadow:0 6px 28px rgba(232,90,10,0.55),inset 0 1px 0 rgba(255,200,150,0.4);transform:translateY(-1px)}

/* MAIN */
.main{flex:1;display:flex;flex-direction:column;padding-top:68px}
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:11px 24px;background:var(--accent);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:'Inter',sans-serif;box-shadow:0 4px 16px rgba(232,90,10,0.3);letter-spacing:-0.1px}
.btn-primary:hover{background:#ff6820;box-shadow:0 6px 24px rgba(232,90,10,0.45);transform:translateY(-1px)}
.btn-primary:active{transform:translateY(0)}
.btn-secondary{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:rgba(0,0,0,0.04);border:1px solid rgba(0,0,0,0.1);border-radius:8px;color:var(--text2);font-size:14px;cursor:pointer;transition:all .2s ease;font-family:'Inter',sans-serif;font-weight:500}
.btn-secondary:hover{border-color:rgba(0,0,0,0.18);color:var(--text);background:rgba(0,0,0,0.07)}
.content{padding:32px 64px 80px;flex:1;width:100%}
/* DASHBOARD HERO CAROUSEL */
.dash-hero-carousel{position:relative;width:100%;height:420px;border-radius:16px;overflow:hidden;margin-bottom:28px;flex-shrink:0}
.dhc-track{display:flex;height:100%;transition:transform .7s cubic-bezier(0.22,1,0.36,1)}
.dhc-slide{min-width:100%;height:100%;background-size:cover;background-position:center;position:relative;flex-shrink:0}
.dhc-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,0.62) 0%,rgba(0,0,0,0.28) 55%,rgba(0,0,0,0.05) 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:40px 48px;z-index:2}
.dhc-text-wrap{flex:1;display:flex;flex-direction:column;justify-content:flex-end;gap:10px;max-width:520px}
.dhc-greeting{font-size:36px;font-weight:700;color:#fff;letter-spacing:-1px;line-height:1.15;text-shadow:0 2px 16px rgba(0,0,0,0.25)}
.dhc-scripture{font-size:14px;color:rgba(255,255,255,0.75);line-height:1.7;font-style:italic;border-left:2px solid rgba(232,90,10,0.7);padding-left:14px;max-width:440px}
.dhc-dots{display:flex;gap:7px;margin-top:20px}
.dhc-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.35);cursor:pointer;transition:all .25s}
.dhc-dot.active{width:22px;border-radius:3px;background:#fff}
.dhc-arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,0.15);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,0.2);color:#fff;font-size:26px;width:44px;height:44px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:3;transition:background .2s;line-height:1;padding-bottom:2px}
.dhc-arrow:hover{background:rgba(255,255,255,0.28)}
.dhc-prev{left:18px}
.dhc-next{right:18px}

.dash-greeting{margin-bottom:48px;animation:hero-in 0.8s 0.15s cubic-bezier(0.22,1,0.36,1) both}
.dash-greeting-text{font-size:16px;font-weight:400;color:var(--text2);margin-bottom:10px}
.dash-scripture{font-size:14px;color:var(--text3);line-height:1.7;font-style:italic;border-left:2px solid rgba(232,90,10,0.3);padding-left:16px;max-width:560px}
.scripture-verse{font-weight:600;font-style:normal;color:var(--accent);font-size:10px;text-transform:uppercase;letter-spacing:1px;display:block;margin-bottom:4px}

/* VIEWS */
.view{display:none}
.view.active{display:block}
@keyframes sui-up{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes sui-fade{from{opacity:0}to{opacity:1}}
@keyframes card-enter{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fade-up{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

/* Stagger child animations */
.view.active .card:nth-child(1){animation-delay:.05s}
.view.active .card:nth-child(2){animation-delay:.1s}
.view.active .card:nth-child(3){animation-delay:.15s}
.view.active .card:nth-child(4){animation-delay:.2s}
.view.active .stat-card:nth-child(1){animation-delay:.05s}
.view.active .stat-card:nth-child(2){animation-delay:.1s}
.view.active .stat-card:nth-child(3){animation-delay:.15s}
.view.active .stat-card:nth-child(4){animation-delay:.2s}

/* STAT CARDS */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin-bottom:48px;border:1px solid rgba(0,0,0,0.07);border-radius:14px;overflow:hidden;background:rgba(0,0,0,0.06)}
.stat-card{background:#fff;border:none;border-radius:0;padding:36px 32px;transition:background .2s ease;position:relative;overflow:hidden;animation:sui-up 0.7s cubic-bezier(0.22,1,0.36,1) both}
.stat-card:nth-child(1){animation-delay:.05s}
.stat-card:nth-child(2){animation-delay:.1s}
.stat-card:nth-child(3){animation-delay:.15s}
.stat-card:nth-child(4){animation-delay:.2s}
@keyframes card-enter{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.stat-card::before{display:none}
.stat-card::after{display:none}
.stat-card:hover{background:rgba(0,0,0,0.015)}
.stat-label{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:20px;font-weight:600}
.stat-val{font-size:52px;font-weight:700;color:var(--text);line-height:1;letter-spacing:-3px}
.stat-sub{font-size:13px;color:var(--text3);margin-top:12px}
.stat-card.accent .stat-val{color:var(--accent)}
.stat-card.accent .stat-val{background:var(--grad-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* CARDS */
.card{background:#fff;border:1px solid rgba(0,0,0,0.07);border-radius:14px;margin-bottom:20px;transition:border-color .2s ease,box-shadow .2s ease;position:relative;overflow:hidden;animation:sui-up 0.7s cubic-bezier(0.22,1,0.36,1) both;box-shadow:0 1px 4px rgba(0,0,0,0.05)}
.card::before{display:none}
.card:hover{border-color:rgba(0,0,0,0.12);box-shadow:0 4px 16px rgba(0,0,0,0.08)}
.card-header{padding:22px 28px 18px;border-bottom:1px solid rgba(0,0,0,0.06);display:flex;align-items:center;justify-content:space-between}
.card-title{font-size:14px;font-weight:600;color:var(--text);letter-spacing:-0.3px}
.card-body{padding:4px 0}
.card-footer{padding:14px 28px;border-top:1px solid rgba(0,0,0,0.06)}

/* CATEGORY COLORS */
.pill-cat-weekly{background:linear-gradient(135deg,rgba(29,158,117,.22),rgba(26,159,212,.16));color:#ffb060;border:1px solid rgba(29,158,117,.3);box-shadow:0 0 10px rgba(29,158,117,.15)}
.pill-cat-series{background:linear-gradient(135deg,rgba(139,114,224,.22),rgba(192,88,208,.16));color:#c49cff;border:1px solid rgba(139,114,224,.3);box-shadow:0 0 10px rgba(139,114,224,.15)}
.pill-cat-summer{background:linear-gradient(135deg,rgba(232,160,32,.22),rgba(232,80,32,.16));color:#ffc850;border:1px solid rgba(232,160,32,.3);box-shadow:0 0 10px rgba(232,160,32,.15)}
.pill-cat-midweek{background:linear-gradient(135deg,rgba(59,141,224,.22),rgba(80,64,224,.16));color:#88c4ff;border:1px solid rgba(59,141,224,.3);box-shadow:0 0 10px rgba(59,141,224,.15)}
.pill-cat-celebration{background:linear-gradient(135deg,rgba(217,79,79,.22),rgba(154,58,212,.16));color:#ff9090;border:1px solid rgba(217,79,79,.3);box-shadow:0 0 10px rgba(217,79,79,.15)}
.pill-cat-camps{background:linear-gradient(135deg,rgba(15,168,168,.22),rgba(31,186,136,.16));color:#50e8e8;border:1px solid rgba(94,201,201,.3);box-shadow:0 0 10px rgba(94,201,201,.15)}

.border-weekly{border-left:3px solid #f5820a}
.border-series{border-left:3px solid #8b72e0}
.border-summer{border-left:3px solid #e8a020}
.border-midweek{border-left:3px solid #3b8de0}
.border-celebration{border-left:3px solid #d94f4f}
.border-camps{border-left:3px solid #5ec9c9}

/* POST ITEMS */
.post-row{display:flex;align-items:center;gap:14px;padding:14px 28px;border-bottom:1px solid rgba(0,0,0,0.05);transition:background .15s}
.post-row:last-child{border-bottom:none}
.post-row:hover{background:rgba(0,0,0,0.02)}
.status-pip{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.pip-idea{background:var(--purple)}
.pip-draft{background:var(--amber)}
.pip-scheduled{background:var(--accent)}
.pip-published{background:#555}
.post-info{flex:1;min-width:0}
.post-name{font-size:11px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.post-meta-row{display:flex;align-items:center;gap:8px;margin-top:3px;flex-wrap:wrap}
.pill{display:inline-flex;align-items:center;gap:3px;padding:3px 9px;border-radius:20px;font-size:10px;font-weight:600}
.pill-fb{background:rgba(80,144,232,0.15);color:#7ab0e8}
.pill-fbcom{background:rgba(60,120,210,0.12);color:#5a90d0}
.pill-ig{background:rgba(232,120,180,0.15);color:#e07ab0}
.pill-yt{background:rgba(224,80,80,0.15);color:#e07a7a}
.pill-tiktok{background:rgba(152,120,232,0.15);color:#a0a0e8}
.pill-scheduled{background:rgba(20,160,120,0.15);color:#5ec9a0}
.pill-draft{background:rgba(200,140,20,0.15);color:#d4a020}
.pill-idea{background:rgba(152,100,224,0.15);color:#a080e0}
.pill-published{background:rgba(255,255,255,0.07);color:#666}

/* PLATFORM CHECKBOXES */
.platform-checks{display:flex;flex-wrap:wrap;gap:8px;padding:4px 0}
.check-item{display:flex;align-items:center;gap:7px;padding:7px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;user-select:none}
.check-item:hover{border-color:var(--border2);background:var(--surface2)}
.check-item input[type=checkbox]{accent-color:var(--accent);width:14px;height:14px;cursor:pointer}
.check-item input[type=checkbox]:checked+span{color:var(--text)}
.check-item:has(input:checked){border-color:var(--accent);background:rgba(255,96,32,0.08)}
.check-item span{font-size:11px;color:var(--text2)}
.post-date-label{font-size:11px;color:var(--text3)}
.post-actions{display:flex;gap:4px;flex-shrink:0;opacity:0;transition:opacity .15s}
.post-row:hover .post-actions{opacity:1}
.icon-btn{background:none;border:none;cursor:pointer;color:var(--text3);padding:5px;border-radius:5px;font-size:10px;line-height:1;transition:all .1s;font-family:'Inter',sans-serif}
.icon-btn:hover{background:var(--surface3);color:var(--text)}

/* TASK ITEMS */
.task-row{display:flex;align-items:center;gap:12px;padding:14px 28px;border-bottom:1px solid rgba(0,0,0,0.05);transition:background .15s}
.task-row:last-child{border-bottom:none}
.task-row:hover{background:rgba(0,0,0,0.02)}
.task-check{width:17px;height:17px;border:1.5px solid var(--border2);border-radius:4px;flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:11px;transition:all .15s}
.task-check.done{background:var(--accent);border-color:var(--accent);color:#fff}
.task-text{font-size:11px;color:var(--text);flex:1}
.task-text.done{text-decoration:line-through;color:var(--text3)}
.task-tag{font-size:10px;font-weight:500;padding:2px 7px;border-radius:20px}
.tag-weekly{background:rgba(20,160,120,0.15);color:#5ec9a0}
.tag-series{background:rgba(152,100,224,0.15);color:#a080e0}
.tag-event{background:rgba(232,120,180,0.15);color:#e07ab0}
.tag-urgent{background:rgba(224,80,80,0.15);color:#e07a7a}
.task-due{font-size:11px;color:var(--text3);white-space:nowrap}
.task-actions{opacity:0;transition:opacity .15s}
.task-row:hover .task-actions{opacity:1}

/* CALENDAR */
.cal-sticky-days{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;padding:14px 20px 10px;background:rgba(245,244,240,0.97);backdrop-filter:blur(32px);-webkit-backdrop-filter:blur(32px);border-bottom:1px solid rgba(0,0,0,0.06);position:sticky;top:68px;z-index:10}
.cal-month-section{margin-bottom:36px;margin-top:12px}
.cal-month-heading{font-size:10px;font-weight:700;color:var(--text);margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-hdr{font-size:11px;font-weight:700;color:var(--text);text-align:center;padding:6px 0;letter-spacing:.3px;text-transform:uppercase}
.cal-day{min-height:160px;background:#fff;border-radius:var(--radius-sm);padding:12px;cursor:pointer;transition:all .16s ease;border:1px solid rgba(0,0,0,0.07);position:relative;box-shadow:0 1px 3px rgba(0,0,0,0.04)}
.cal-day.past{opacity:.5}
.cal-day.past:hover{opacity:.75}
.cal-day:hover{background:rgba(0,0,0,0.01);border-color:rgba(0,0,0,0.13)}
.cal-day.today{border-color:rgba(232,82,10,.5)}
.cal-day.empty{background:none;cursor:default;border:none}
.cal-day.selected{border-color:var(--accent);background:rgba(255,96,32,0.07);box-shadow:0 0 0 1px rgba(255,96,32,0.3),0 0 12px rgba(255,96,32,0.15)}
.cal-day.hover-sync{background:var(--surface3);border-color:var(--border2)}
.cal-add-btn{position:absolute;top:7px;right:7px;width:20px;height:20px;border-radius:50%;background:var(--accent);color:#fff;border:none;font-size:10px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;font-family:'Inter',sans-serif;font-weight:400}
.cal-day:hover .cal-add-btn{opacity:1}
.cal-day.selected .cal-add-btn{opacity:.7}
.cal-day.selected:hover .cal-add-btn{opacity:1}
.cal-num{font-size:11px;font-weight:600;color:var(--text);margin-bottom:8px}
.today-num{background:var(--accent);color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600}
.cal-pip{font-size:10px;padding:4px 9px;border-radius:6px;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4;font-weight:700;border-left:4px solid transparent}
.cal-pip.weekly{background:rgba(245,130,10,0.18);color:#7a3200;border-left-color:#f5820a;box-shadow:0 1px 6px rgba(245,130,10,.18)}
.cal-pip.series{background:rgba(139,114,224,0.18);color:#3a1e8a;border-left-color:#8b72e0;box-shadow:0 1px 6px rgba(139,114,224,.18)}
.cal-pip.summer{background:rgba(232,160,32,0.18);color:#6a4a00;border-left-color:#e8a020;box-shadow:0 1px 6px rgba(232,160,32,.18)}
.cal-pip.midweek{background:rgba(59,141,224,0.18);color:#0a3880;border-left-color:#3b8de0;box-shadow:0 1px 6px rgba(59,141,224,.18)}
.cal-pip.celebration{background:rgba(217,79,79,0.18);color:#7a1010;border-left-color:#d94f4f;box-shadow:0 1px 6px rgba(217,79,79,.18)}
.cal-pip.camps{background:rgba(94,201,201,0.18);color:#0a5858;border-left-color:#5ec9c9;box-shadow:0 1px 6px rgba(94,201,201,.18)}
.week-post.weekly{background:rgba(255,96,32,0.1);border-left-color:#f5820a}
.week-post.series{background:rgba(139,114,224,0.1);border-left-color:#8b72e0}
.week-post.summer{background:rgba(232,160,32,0.1);border-left-color:#e8a020}
.week-post.midweek{background:rgba(59,141,224,0.1);border-left-color:#3b8de0}
.week-post.celebration{background:rgba(217,79,79,0.1);border-left-color:#d94f4f}
.week-post.camps{background:rgba(94,201,201,0.1);border-left-color:#5ec9c9}
.cal-more{font-size:10px;color:var(--text2);font-weight:500;margin-top:2px}
.pip-warn{font-size:9px;margin-right:3px;color:#f5a623;vertical-align:middle}

/* Post modal two-column layout */
.post-modal-layout{display:grid;grid-template-columns:1fr 320px;min-height:560px;align-items:stretch}
.post-modal-left{padding:20px 20px 20px 24px;border-right:1px solid var(--border);display:flex;flex-direction:column;gap:0}
.post-modal-left .field-row{flex-shrink:0}
.post-modal-right{padding:20px 24px 20px 20px;overflow-y:auto;display:flex;flex-direction:column;gap:4px}
.post-ready-box{background:rgba(31,186,136,.06);border:1px solid rgba(31,186,136,.2);border-radius:var(--radius-sm);padding:12px 14px;margin-top:8px}
.post-task-box{background:rgba(0,0,0,.03);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;margin-top:8px}
/* Caption generator — fills remaining space in left column */
.caption-gen-full{flex:1;display:flex;flex-direction:column;border-top:1px solid var(--border);margin-top:14px;padding-top:14px;min-height:0}
#caption-chat-thread{flex:1;min-height:160px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;background:rgba(0,0,0,.04);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px}
#caption-chat-thread:empty::before{content:'';}
#caption-chat-thread::-webkit-scrollbar{width:4px}
#caption-chat-thread::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}

/* WEEKLY DETAIL */
.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;min-height:220px}
.week-col{display:flex;flex-direction:column;gap:6px;border-radius:var(--radius-sm);padding:8px;border:1px solid transparent;transition:all .15s;cursor:pointer}
.week-col:hover{background:rgba(0,0,0,.02);border-color:var(--border)}
.week-col.selected{background:rgba(255,96,32,0.07);border-color:var(--accent);box-shadow:0 0 0 1px rgba(255,96,32,0.3),0 0 12px rgba(255,96,32,0.12)}
.week-col.hover-sync{background:rgba(255,255,255,.03);border-color:var(--border2)}
.week-col-hdr{display:flex;align-items:flex-start;justify-content:space-between;padding-bottom:8px;border-bottom:1px solid var(--border)}
.week-col-hdr-left{text-align:center;flex:1}
.week-day-name{font-size:10px;font-weight:600;color:var(--text3);letter-spacing:.5px;text-transform:uppercase}
.week-day-num{font-size:22px;font-weight:600;color:var(--text);margin-top:3px;line-height:1}
.week-day-num.today-week{color:var(--accent)}
.week-col-hdr-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.week-add-btn{width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;border:none;font-size:11px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;font-family:'Inter',sans-serif;flex-shrink:0}
.week-col:hover .week-add-btn{opacity:1}
.week-col.selected .week-add-btn{opacity:.7}
.week-col.selected:hover .week-add-btn{opacity:1}
.week-events-in-hdr{display:flex;flex-direction:column;gap:3px;padding:6px 0 2px}
.week-col-body{display:flex;flex-direction:column;gap:5px;padding-top:8px;flex:1}
.week-post{border-radius:7px;padding:8px 10px;cursor:pointer;transition:opacity .15s;border-left:4px solid transparent;position:relative}
.week-post:hover{opacity:.9}
.week-post-title{font-size:11px;font-weight:700;color:#1a1008;line-height:1.3;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:18px}
.week-post-meta{font-size:10px;opacity:.8;font-weight:500;color:#1a1008}
.post-delete-btn{position:absolute;top:3px;right:3px;background:rgba(255,255,255,.2);border:none;color:#fff;font-size:11px;font-weight:700;line-height:1;width:16px;height:16px;border-radius:3px;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center}
.post-delete-btn:hover{background:rgba(220,60,60,.85)}
.draggable-post{cursor:grab}
.draggable-post:active{cursor:grabbing}
.drag-over{background:rgba(29,158,117,.15) !important;outline:2px dashed #f5820a !important;outline-offset:-2px}
.week-post.weekly{background:rgba(245,130,10,0.18);border-left-color:#f5820a}
.week-post.series{background:rgba(139,114,224,0.18);border-left-color:#8b72e0}
.week-post.summer{background:rgba(232,160,32,0.18);border-left-color:#e8a020}
.week-post.midweek{background:rgba(59,141,224,0.18);border-left-color:#3b8de0}
.week-post.celebration{background:rgba(217,79,79,0.18);border-left-color:#d94f4f}
.week-post.camps{background:rgba(94,201,201,0.18);border-left-color:#5ec9c9}
.week-empty{font-size:11px;color:var(--text2);text-align:center;padding-top:16px}

/* PROJECTS */
.proj-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:18px;margin-bottom:12px;transition:border-color .15s,box-shadow .15s;box-shadow:0 1px 4px rgba(0,0,0,0.05)}
.proj-card:hover{border-color:rgba(0,0,0,0.12);box-shadow:0 4px 16px rgba(0,0,0,0.08)}

/* PROJECT DETAIL PAGE */
.pd-back-row{display:flex;align-items:center;margin-bottom:24px}
.pd-grid{display:grid;grid-template-columns:340px 1fr;gap:20px;align-items:start}
.pd-left{display:flex;flex-direction:column;gap:20px}
.pd-right{position:sticky;top:88px}
.pd-section-label{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px}
.pd-color-row{display:flex;gap:12px;flex-wrap:wrap}
.pd-color-swatch{display:flex;flex-direction:column;align-items:center;gap:5px}
.pd-color-block{width:52px;height:52px;border-radius:10px;border:1.5px solid rgba(0,0,0,0.1);box-shadow:0 2px 8px rgba(0,0,0,0.1)}
.pd-color-name{font-size:10px;font-weight:600;color:var(--text2)}
.pd-color-hex{font-size:10px;color:var(--text3);font-family:'Menlo','Monaco',monospace}
.pd-font-row{display:flex;gap:12px;flex-wrap:wrap}
.pd-font-chip{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px 14px;min-width:120px}
.pd-font-role{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text3);margin-bottom:3px}
.pd-font-name{font-size:14px;font-weight:600;color:var(--text);letter-spacing:-0.2px}
.pd-mood-tag{display:inline-block;background:rgba(232,90,10,0.1);border:1px solid rgba(232,90,10,0.25);color:var(--accent);font-size:12px;font-weight:600;padding:5px 14px;border-radius:20px}
.pd-brief-text{font-size:13px;color:var(--text);line-height:1.7}
.pd-ai-thread{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:10px;min-height:200px;max-height:420px}
.pd-ai-thread::-webkit-scrollbar{width:4px}
.pd-ai-thread::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}
.pd-ai-empty{font-size:13px;color:var(--text3);line-height:1.7;text-align:center;padding:32px 16px;align-self:center}
.pd-ai-input-row{display:flex;gap:10px;padding:14px 16px;border-top:1px solid var(--border);align-items:flex-end}
.pd-ai-input{flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;padding:10px 12px;font-family:'Inter',sans-serif;outline:none;resize:none;line-height:1.5;transition:border-color .15s}
.pd-ai-input:focus{border-color:var(--accent)}

/* Color picker swatches in modal */
.proj-color-swatch-wrap{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer}
.proj-color-swatch-wrap input[type=color]{width:44px;height:44px;border:none;border-radius:8px;cursor:pointer;padding:0;background:none;border:1.5px solid rgba(0,0,0,0.1);overflow:hidden}
.proj-color-label{font-size:10px;color:var(--text3);font-weight:500}

@media(max-width:900px){.pd-grid{grid-template-columns:1fr}.pd-right{position:static}}
.proj-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px}
.proj-name{font-size:10px;font-weight:600;color:var(--text)}
.proj-date{font-size:11px;color:var(--text3);margin-top:2px}
.proj-desc{font-size:10px;color:var(--text2);line-height:1.6;margin-bottom:12px}
.progress-track{height:3px;background:var(--surface3);border-radius:4px;margin-bottom:5px}
.progress-fill{height:100%;border-radius:4px;background:var(--accent);transition:width .3s}
.progress-label{font-size:11px;color:var(--text3)}

/* IDEAS */
.idea-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.idea-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;cursor:pointer;transition:all .15s}
.idea-card:hover{border-color:var(--border2);background:var(--surface2)}
.idea-title{font-size:11px;font-weight:500;color:var(--text);margin-bottom:5px}
.idea-type{font-size:10px;color:var(--text3);margin-bottom:6px}
.idea-notes{font-size:11px;color:var(--text2);line-height:1.5}

/* MONTH NAV */
.month-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.month-label{font-size:10px;font-weight:600;color:var(--text)}
.month-btn{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:5px 10px;color:var(--text2);cursor:pointer;font-size:11px;font-family:'Inter',sans-serif;transition:all .15s}
.month-btn:hover{background:var(--surface2)}

/* FILTERS */
.filter-bar{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
select.filter-select{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text2);font-size:10px;padding:7px 10px;cursor:pointer;font-family:'Inter',sans-serif;outline:none}
select.filter-select:focus{border-color:var(--accent)}

/* MODALS */
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.2);z-index:200;align-items:center;justify-content:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.overlay.open{display:flex;animation:fade-in .2s ease}
@keyframes fade-in{from{opacity:0}to{opacity:1}}
.modal{background:rgba(250,249,246,0.98);backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);border:1px solid rgba(0,0,0,0.1);border-radius:18px;padding:0;width:min(500px,94vw);max-height:90vh;overflow-y:auto;box-shadow:0 24px 60px rgba(0,0,0,0.15),0 1px 0 rgba(255,255,255,0.8);animation:slide-up .25s ease}
@keyframes slide-up{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.modal-head{padding:20px 22px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-title{font-size:11px;font-weight:600;color:var(--text)}
.modal-close{background:none;border:none;color:var(--text3);cursor:pointer;font-size:10px;line-height:1;padding:0;font-family:'Inter',sans-serif}
.modal-body{padding:20px 22px}
.field-row{margin-bottom:14px}
.field-label{display:block;font-size:11px;font-weight:600;color:var(--text3);letter-spacing:.4px;text-transform:uppercase;margin-bottom:5px}
input[type=text],input[type=date],textarea,select.field-select{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:11px;padding:9px 11px;font-family:'Inter',sans-serif;outline:none;transition:border-color .15s}
input[type=text]:focus,input[type=date]:focus,textarea:focus,select.field-select:focus{border-color:var(--accent)}
textarea{resize:vertical;min-height:80px;line-height:1.5}
input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.4)}
.modal-actions{padding:14px 22px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}
.btn-cancel{padding:9px 18px;background:rgba(0,0,0,0.04);border:1px solid rgba(0,0,0,0.1);border-radius:50px;color:var(--text2);font-size:11px;cursor:pointer;font-family:'Inter',sans-serif;transition:all .15s}
.btn-cancel:hover{background:rgba(0,0,0,0.07);color:var(--text)}
.btn-save{padding:9px 22px;background:var(--grad-primary);border:none;border-radius:50px;color:#fff;font-size:11px;font-weight:700;cursor:pointer;font-family:'Inter',sans-serif;transition:all .22s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 20px rgba(255,96,32,0.4)}
.btn-save:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,96,32,0.55)}
/* Caption generator */
/* Basecamp setup modal */
.bc-step-box{display:flex;align-items:flex-start;gap:14px;padding:12px 0;border-bottom:1px solid var(--border)}
.bc-step-box:last-of-type{border-bottom:none}
.bc-step-num{width:22px;height:22px;background:rgba(255,96,32,.15);border:1px solid rgba(255,96,32,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--accent);flex-shrink:0;margin-top:1px}
.bc-step-title{font-size:11px;font-weight:500;color:var(--text);margin-bottom:6px}
.bc-step-code{font-family:'Menlo','Monaco','Courier New',monospace;font-size:11px;background:rgba(0,0,0,.3);border:1px solid var(--border);border-radius:5px;padding:6px 10px;color:var(--accent);word-break:break-all}
/* Caption generator chat */
.caption-gen-box{background:rgba(255,96,32,0.05);border:1px solid rgba(255,96,32,0.15);border-radius:var(--radius-sm);padding:12px;margin-bottom:14px}
#caption-chat-thread{display:flex;flex-direction:column;gap:8px;max-height:220px;overflow-y:auto;margin-bottom:8px;padding-right:2px}
#caption-chat-thread::-webkit-scrollbar{width:3px}
#caption-chat-thread::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}
.caption-bubble-user{align-self:flex-end;background:rgba(255,96,32,0.15);border:1px solid rgba(255,96,32,0.25);border-radius:10px 10px 2px 10px;padding:7px 11px;font-size:10px;color:var(--text);max-width:85%;line-height:1.5}
.caption-bubble-ai{align-self:flex-start;background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:10px 10px 10px 2px;padding:7px 11px;font-size:10px;color:var(--text2);max-width:90%;line-height:1.6;white-space:pre-wrap}
.caption-use-btn{background:rgba(255,96,32,0.12);border:1px solid rgba(255,96,32,0.3);border-radius:5px;color:var(--accent);font-size:10px;font-weight:600;padding:4px 10px;cursor:pointer;font-family:'Inter',sans-serif;transition:all .15s}
.caption-use-btn:hover{background:rgba(255,96,32,0.22)}
.caption-apikey-notice{font-size:11px;color:var(--text3);text-align:center;padding:8px 0;align-self:center}
.caption-apikey-card{max-width:100%!important;width:100%;line-height:1.6;font-size:10px}
.caption-gen-label{font-size:10px;font-weight:600;color:var(--accent);letter-spacing:.6px;text-transform:uppercase;margin-bottom:8px}
.field-input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:11px;padding:9px 11px;font-family:'Inter',sans-serif;outline:none;transition:border-color .15s}
.field-input:focus{border-color:var(--accent)}
/* Day detail modal */
.day-modal-event-row{display:flex;align-items:center;gap:12px;padding:11px 20px;border-bottom:1px solid var(--border)}
.day-modal-event-row:last-child{border-bottom:none}
.day-event-del-btn{background:none;border:1px solid rgba(224,85,85,.25);border-radius:5px;color:var(--red);font-size:11px;padding:4px 10px;cursor:pointer;white-space:nowrap;font-family:'Inter',sans-serif;transition:all .15s;flex-shrink:0}
.day-event-del-btn:hover{background:rgba(224,85,85,.1)}
.day-modal-post-row{display:flex;align-items:flex-start;gap:12px;padding:12px 20px;border-bottom:1px solid var(--border)}
.day-modal-post-row:last-child{border-bottom:none}

/* ADD ROW */
.add-row{display:flex;align-items:center;gap:8px;padding:14px 28px;color:var(--text3);font-size:12px;cursor:pointer;border-top:1px solid rgba(0,0,0,0.05);transition:all .15s}
.add-row:hover{background:rgba(0,0,0,0.02);color:var(--accent)}

/* EMPTY STATE */
.empty{text-align:center;padding:36px 20px;color:var(--text3);font-size:11px;line-height:1.6}
.empty-icon{font-size:28px;margin-bottom:8px;opacity:.4}

/* TOAST */
.toast{position:fixed;bottom:24px;right:24px;background:rgba(255,255,255,0.97);backdrop-filter:blur(16px);border:1px solid rgba(0,0,0,0.1);border-radius:var(--radius);padding:11px 18px;font-size:11px;color:var(--text);z-index:999;display:none;animation:slide-up .2s ease;box-shadow:0 8px 32px rgba(0,0,0,0.12)}
@keyframes slideUp{from{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}

/* APPLE CALENDAR EVENTS */
.cal-pip.apple{background:none;color:var(--text3);border-left:2px solid var(--border2);font-weight:400;opacity:.75;display:flex;align-items:center;gap:3px;overflow:visible;white-space:nowrap}
.cal-pip-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.cal-pip-hide{display:none;background:none;border:none;color:var(--text3);font-size:9px;cursor:pointer;padding:0;flex-shrink:0;line-height:1;opacity:.5}
.cal-pip-hide:hover{opacity:1;color:var(--red)}
.cal-pip.apple:hover .cal-pip-hide{display:inline-block}
.cal-pip.apple.multi-cont{border-left-color:rgba(255,96,32,.4);opacity:.6}
.cal-pip.apple.multi-span{border-left-color:rgba(255,96,32,.55);opacity:.7}
.week-event-chip{display:flex;align-items:center;gap:4px;background:transparent;border-left:2px solid var(--border2);border-radius:0 3px 3px 0;padding:3px 4px 3px 5px;min-width:0}
.week-event-chip-icon{font-size:10px;flex-shrink:0;line-height:1;opacity:.5}
.week-event-chip-label{font-size:10px;font-weight:500;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}
.week-event-chip-hide{background:none;border:none;color:var(--text3);opacity:.35;font-size:10px;cursor:pointer;padding:0 0 0 2px;flex-shrink:0;line-height:1}
.week-event-chip-hide:hover{opacity:1;color:var(--text)}
.apple-event-row{display:flex;align-items:center;gap:10px;padding:9px 18px;border-bottom:1px solid var(--border)}
.apple-event-row:last-child{border-bottom:none}
.apple-dot{width:7px;height:7px;border-radius:50%;background:#ff3b30;flex-shrink:0}
.cal-sync-pulse{animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* INSPIRATION GRID */
.inspiration-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px;padding:16px 20px}
.inspo-card{background:#fff;border:1px solid rgba(0,0,0,0.07);border-radius:var(--radius);padding:16px;transition:all .22s;cursor:default;animation:fade-up .3s ease both;box-shadow:0 1px 4px rgba(0,0,0,0.05)}
.inspo-card:nth-child(1){animation-delay:.05s}
.inspo-card:nth-child(2){animation-delay:.1s}
.inspo-card:nth-child(3){animation-delay:.15s}
.inspo-card:nth-child(4){animation-delay:.2s}
.inspo-card:nth-child(5){animation-delay:.25s}
.inspo-card:nth-child(6){animation-delay:.3s}
@keyframes fade-up{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes card-dismiss{0%{opacity:1;transform:scale(1) translateY(0)}100%{opacity:0;transform:scale(0.92) translateY(-8px)}}
.inspo-card:hover{border-color:rgba(0,0,0,0.12);transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,0.09)}
.inspo-platform{font-size:9px;font-weight:700;color:var(--accent);letter-spacing:.6px;text-transform:uppercase;margin-bottom:5px}
.inspo-title{font-size:11px;font-weight:700;color:var(--text);margin-bottom:6px;letter-spacing:-0.1px}
.inspo-desc{font-size:11px;color:var(--text3);line-height:1.6}
.inspo-actions{display:flex;gap:6px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}
.inspo-save-btn{background:linear-gradient(135deg,rgba(255,96,32,0.18),rgba(255,94,0,0.12));border:1px solid rgba(255,96,32,0.3);border-radius:20px;color:#ffb060;font-size:10px;font-weight:700;padding:5px 12px;cursor:pointer;font-family:'Inter',sans-serif;transition:all .15s;flex:1}
.inspo-save-btn:hover{background:linear-gradient(135deg,rgba(255,96,32,0.32),rgba(26,159,212,0.24));box-shadow:0 0 12px rgba(255,96,32,0.25)}
.inspo-deny-btn{background:none;border:1px solid var(--border);border-radius:5px;color:var(--text3);font-size:10px;padding:4px 10px;cursor:pointer;font-family:'Inter',sans-serif;transition:all .15s}
.inspo-deny-btn:hover{border-color:var(--border2);color:var(--text)}

/* ANALYTICS */
.analytics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:14px}
.an-card{background:#fff;border:1px solid rgba(0,0,0,0.07);border-radius:var(--radius);padding:16px;transition:transform .2s,box-shadow .2s;box-shadow:0 1px 4px rgba(0,0,0,0.05)}
.an-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,0.09)}
.an-platform{font-size:10px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;margin-bottom:8px}
.an-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px}
.an-label{font-size:11px;color:var(--text3)}
.an-val{font-size:10px;font-weight:600;color:var(--text)}
.an-sub{font-size:10px;color:var(--text3);margin-top:2px}
.an-week{font-size:10px;color:var(--text3);margin-bottom:12px}
.analytics-note{font-size:11px;color:var(--text3);padding-top:10px;border-top:1px solid var(--border)}
.analytics-note a{color:var(--accent)}
.an-empty{font-size:11px;color:var(--text3);text-align:center;padding:24px 0}

/* TWO COL */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:900px){
  .sidebar{width:180px}
  .main{margin-left:180px}
  .stat-grid{grid-template-columns:1fr 1fr}
  .two-col{grid-template-columns:1fr}
}
@media(max-width:640px){
  .sidebar{display:none}
  .main{margin-left:0}
  .stat-grid{grid-template-columns:1fr 1fr}
}

/* ANIMATIONS */
@keyframes badge-pop{from{transform:scale(0.5);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes float-up{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
@keyframes glow-pulse{0%,100%{box-shadow:0 0 16px rgba(255,96,32,0.4)}50%{box-shadow:0 0 28px rgba(255,96,32,0.7),0 0 48px rgba(255,96,32,0.3)}}

/* Post rows — slide in on load */
.post-row{animation:row-enter .3s cubic-bezier(.4,0,.2,1) both}
@keyframes row-enter{from{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:translateX(0)}}
.post-row:nth-child(1){animation-delay:.04s}
.post-row:nth-child(2){animation-delay:.08s}
.post-row:nth-child(3){animation-delay:.12s}
.post-row:nth-child(4){animation-delay:.16s}
.post-row:nth-child(5){animation-delay:.2s}

/* Task rows */
.task-row{animation:row-enter .3s cubic-bezier(.4,0,.2,1) both}
.task-check.done{animation:check-pop .25s cubic-bezier(.34,1.56,.64,1)}
@keyframes check-pop{0%{transform:scale(0.6)}100%{transform:scale(1)}}

/* Overlay open */
.overlay.open{animation:overlay-in .2s ease}
@keyframes overlay-in{from{opacity:0}to{opacity:1}}
.modal{animation:modal-rise .28s cubic-bezier(.34,1.2,.64,1)}
@keyframes modal-rise{from{opacity:0;transform:translateY(24px) scale(0.97)}to{opacity:1;transform:translateY(0) scale(1)}}


/* Toast slide up */
.toast{animation:toast-in .25s cubic-bezier(.34,1.2,.64,1)}
@keyframes toast-in{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* Calendar pips */
.cal-pip{animation:pip-in .2s ease both}
@keyframes pip-in{from{opacity:0;transform:scaleX(0.8)}to{opacity:1;transform:scaleX(1)}}

/* Logo dot float */
.logo-dot{animation:pulse-dot 3s ease-in-out infinite,float-up 4s ease-in-out infinite}

/* +Note button */
.btn-add-note{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:12px;font-weight:600;font-family:'Inter',sans-serif;cursor:pointer;transition:all .2s;letter-spacing:0.2px}
.btn-add-note:hover{background:#d14e08;transform:translateY(-1px);box-shadow:0 4px 12px rgba(232,90,10,0.35)}

/* STICKY NOTES */
.sticky-note{position:absolute;width:180px;min-height:120px;border-radius:4px 12px 12px 4px;padding:10px 10px 32px;box-shadow:0 4px 16px rgba(0,0,0,0.15),0 1px 4px rgba(0,0,0,0.1);cursor:grab;user-select:none;pointer-events:all;transition:box-shadow .15s,transform .15s;font-family:'Inter',sans-serif;font-size:12px;line-height:1.5;animation:note-in .25s cubic-bezier(0.22,1,0.36,1) both}
.sticky-note:active{cursor:grabbing;box-shadow:0 12px 32px rgba(0,0,0,0.22);transform:rotate(1.5deg) scale(1.03);z-index:9999!important}
.sticky-note textarea{width:100%;height:80px;background:none;border:none;outline:none;resize:none;font-family:'Inter',sans-serif;font-size:12px;line-height:1.5;color:rgba(0,0,0,0.75);cursor:text;font-weight:500}
.sticky-note textarea::placeholder{color:rgba(0,0,0,0.3)}
.sticky-note-toolbar{position:absolute;bottom:6px;left:8px;right:8px;display:flex;align-items:center;gap:4px}
.sticky-color-dot{width:12px;height:12px;border-radius:50%;cursor:pointer;border:1.5px solid rgba(0,0,0,0.12);transition:transform .15s;flex-shrink:0}
.sticky-color-dot:hover{transform:scale(1.3)}
.sticky-del-btn{margin-left:auto;background:none;border:none;font-size:14px;cursor:pointer;color:rgba(0,0,0,0.3);padding:0 2px;line-height:1;transition:color .15s}
.sticky-del-btn:hover{color:rgba(0,0,0,0.65)}
@keyframes note-in{from{opacity:0;transform:scale(0.85) rotate(-4deg)}to{opacity:1;transform:scale(1) rotate(0deg)}}

/* Content inspo card visual */
.inspo-visual{width:100%;aspect-ratio:4/3;border-radius:8px;overflow:hidden;margin-bottom:10px;background:#f5f4f0}
.inspo-visual svg{width:100%;height:100%}
/* Post published checkmark */
.post-check-btn{background:none;border:none;cursor:pointer;padding:0;display:flex;align-items:center;flex-shrink:0;opacity:0.4;transition:opacity .15s,transform .15s}
.post-check-btn:hover{opacity:1;transform:scale(1.15)}
.post-check-btn.checked{opacity:1}
.post-row-done{opacity:0.65}

/* Inspo save choice */
.inspo-choice-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px 14px;background:rgba(0,0,0,0.03);border:1.5px solid rgba(0,0,0,0.08);border-radius:12px;cursor:pointer;transition:all .2s;font-family:'Inter',sans-serif;text-align:center}
.inspo-choice-btn:hover{border-color:var(--accent);background:rgba(232,90,10,0.05);transform:translateY(-2px);box-shadow:0 4px 16px rgba(232,90,10,0.12)}
.inspo-choice-icon{font-size:28px;line-height:1}
.inspo-choice-label{font-size:14px;font-weight:600;color:var(--text)}
.inspo-choice-sub{font-size:11px;color:var(--text3);line-height:1.4}

/* Photo manager */
.pm-row{display:flex;align-items:center;gap:10px;padding:7px 10px;background:rgba(0,0,0,0.03);border:1px solid rgba(0,0,0,0.07);border-radius:8px;cursor:grab;transition:background .15s,box-shadow .15s;user-select:none}
.pm-row:active{cursor:grabbing}
.pm-row.pm-dragging{opacity:0.45}
.pm-row.pm-over{border-color:var(--accent);background:rgba(232,90,10,0.07);box-shadow:0 0 0 2px rgba(232,90,10,0.2)}
.pm-handle{font-size:16px;color:var(--text3);flex-shrink:0;cursor:grab;line-height:1}
.pm-thumb{width:44px;height:30px;object-fit:cover;border-radius:4px;flex-shrink:0;background:#eee}
.pm-name{flex:1;font-size:12px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pm-crop-btn{background:none;border:1px solid rgba(0,0,0,0.12);border-radius:6px;font-size:13px;cursor:pointer;padding:3px 7px;color:var(--text3);transition:all .15s;flex-shrink:0}
.pm-crop-btn:hover{background:rgba(0,0,0,0.06);color:var(--text)}
.pm-toggle{position:relative;display:inline-block;width:34px;height:20px;flex-shrink:0}
.pm-toggle input{opacity:0;width:0;height:0}
.pm-toggle-track{position:absolute;inset:0;border-radius:20px;background:#ccc;transition:.25s;cursor:pointer}
.pm-toggle-track::before{content:'';position:absolute;width:14px;height:14px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.25s}
.pm-toggle input:checked+.pm-toggle-track{background:var(--accent)}
.pm-toggle input:checked+.pm-toggle-track::before{transform:translateX(14px)}

/* Inspo detail modal */
.inspo-detail-block{background:rgba(0,0,0,0.03);border-radius:10px;padding:14px 16px}
.inspo-detail-label{font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--accent);margin-bottom:6px}
.inspo-detail-val{font-size:14px;color:var(--text2);line-height:1.6}
.inspo-detail-tips{margin:0;padding-left:18px;font-size:13px;color:var(--text2);line-height:1.8}
