/* ============================================================
   BIASDESK — Notebook Manager · "Studio" theme
   Soft lavender canvas · white 22px cards · charcoal pills ·
   violet accent · pastel note chips · Plus Jakarta Sans
   ============================================================ */
:root{
  --canvas:#ECEBF2;          /* lavender-gray page background   */
  --card:#FFFFFF;            /* surfaces                        */
  --line:#EAE7F0;            /* hairline borders                */
  --ink:#17161C;             /* charcoal — text / active pills  */
  --ink-2:#5B5966;           /* secondary text                  */
  --ink-3:#9A97A6;           /* muted text                      */
  --violet:#8B5CF6;          /* brand accent                    */
  --violet-soft:#EFE9FE;     /* accent fill                     */
  --shadow:0 8px 28px rgba(23,22,28,.07);
  --shadow-lg:0 18px 48px rgba(23,22,28,.13);
  --r:22px; --r-sm:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--canvas);color:var(--ink);min-height:100vh;font-size:14.5px;
 background-image:radial-gradient(circle at 0% 0%, rgba(139,92,246,.07) 0, transparent 38%),
                  radial-gradient(circle at 100% 100%, rgba(244,114,182,.06) 0, transparent 40%)}
a{color:inherit}
button{font-family:inherit}

/* ============ APP SHELL ============ */
.shell{display:flex;min-height:100vh}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.content{flex:1;padding:22px 28px 60px;max-width:1240px;width:100%;margin:0 auto;min-width:0}

/* ============ SIDEBAR ============ */
.sidebar{width:248px;flex:none;background:var(--card);border-right:1.5px solid var(--line);padding:20px 16px;
 display:flex;flex-direction:column;gap:6px;position:sticky;top:0;height:100vh;overflow-y:auto;z-index:60}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;padding:6px 8px 18px}
.brand-mark{width:40px;height:40px;border-radius:13px;background:linear-gradient(135deg,var(--violet),#6D3EF2);
 display:flex;align-items:center;justify-content:center;font-size:19px;box-shadow:0 6px 14px rgba(139,92,246,.35)}
.brand-txt{font-weight:800;font-size:16.5px;letter-spacing:-.2px;line-height:1.1}
.brand-txt small{display:block;font-size:9px;font-weight:800;letter-spacing:2px;color:var(--ink-3)}
.nav-label{font-size:10.5px;font-weight:800;letter-spacing:1.6px;text-transform:uppercase;color:var(--ink-3);padding:14px 10px 7px}
.nav{display:flex;flex-direction:column;gap:4px}
.nav-item{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:14px;text-decoration:none;
 font-weight:700;font-size:13.8px;color:var(--ink-2);transition:background .12s,color .12s}
.nav-item:hover{background:#F4F2F9;color:var(--ink)}
.nav-item.on{background:var(--ink);color:#fff;box-shadow:0 8px 18px rgba(23,22,28,.28)}
.nav-item.sub{padding:9px 13px;font-size:13px}
.ni-ic{width:20px;text-align:center;font-size:15px;font-style:normal}
.ni-badge{margin-left:auto;background:var(--violet-soft);color:var(--violet);font-size:11px;font-weight:800;
 padding:2px 9px;border-radius:10px;min-width:24px;text-align:center}
.nav-item.on .ni-badge{background:rgba(255,255,255,.18);color:#fff}
.ni-badge.soft{background:#F4F2F9;color:var(--ink-2)}
.side-foot{margin-top:auto;border-top:1.5px solid var(--line);padding-top:14px;display:flex;align-items:center;gap:8px}
.sf-user{display:flex;align-items:center;gap:9px;min-width:0;flex:1}
.sf-av,.uc-av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#F9A8D4,var(--violet));
 color:#fff;font-weight:800;font-size:13px;display:inline-flex;align-items:center;justify-content:center;flex:none}
.sf-name{font-weight:700;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sf-logout{font-size:12px;font-weight:800;color:var(--ink-3);text-decoration:none;white-space:nowrap}
.sf-logout:hover{color:#D6455D}

/* ============ TOPBAR ============ */
.topbar{display:flex;align-items:center;gap:14px;padding:16px 28px 0;max-width:1240px;width:100%;margin:0 auto}
.searchbox{flex:1;max-width:520px;display:flex;align-items:center;background:var(--card);border:1.5px solid var(--line);
 border-radius:18px;padding:4px 6px 4px 16px;box-shadow:var(--shadow)}
.searchbox .sb-ic{font-size:14px;opacity:.55;margin-right:8px}
.searchbox input{flex:1;border:none;background:none;font-size:14px;font-family:inherit;color:var(--ink);min-width:50px;padding:9px 0}
.searchbox input:focus{outline:none}
.searchbox input::placeholder{color:var(--ink-3)}
.searchbox button{border:none;background:var(--ink);color:#fff;padding:9px 18px;border-radius:13px;font-weight:800;font-size:13px;cursor:pointer}
.top-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.tb-btn{width:40px;height:40px;border-radius:14px;background:var(--card);border:1.5px solid var(--line);display:inline-flex;
 align-items:center;justify-content:center;font-size:18px;font-weight:800;text-decoration:none;color:var(--ink);box-shadow:var(--shadow)}
.tb-btn:hover{background:var(--violet);border-color:var(--violet);color:#fff}
.user-chip{display:inline-flex;align-items:center;gap:9px;background:var(--card);border:1.5px solid var(--line);
 border-radius:18px;padding:4px 16px 4px 5px;font-size:13px;font-weight:800;box-shadow:var(--shadow);white-space:nowrap}

/* hamburger / drawer (mobile) */
.nav-toggle{display:none}
.hamburger{display:none;width:40px;height:40px;border-radius:13px;background:var(--card);border:1.5px solid var(--line);
 flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;flex:none}
.hamburger span{width:16px;height:2px;border-radius:2px;background:var(--ink)}
.nav-overlay{display:none}

/* ============ PAGE HEADINGS ============ */
.crumbs{font-size:12.5px;font-weight:700;color:var(--ink-3);margin-bottom:6px}
.crumbs b{color:var(--ink-2)}
.page-head{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:20px}
.page-title{font-size:27px;font-weight:800;letter-spacing:-.6px}
.page-sub{color:var(--ink-3);font-size:13px;font-weight:600;width:100%;margin-top:-8px}
.pro-chip{display:inline-flex;align-items:center;gap:6px;background:var(--violet-soft);color:var(--violet);
 font-size:12px;font-weight:800;padding:5px 13px;border-radius:12px}
.head-actions{margin-left:auto;display:flex;gap:10px;flex-wrap:wrap}

/* buttons */
.btn-add{background:var(--ink);color:#fff;border:none;padding:11px 20px;border-radius:14px;font-size:13.5px;font-weight:800;
 cursor:pointer;display:inline-flex;align-items:center;gap:8px;text-decoration:none;box-shadow:0 8px 18px rgba(23,22,28,.25);transition:transform .1s}
.btn-add:hover{transform:translateY(-1px)}
.btn-import{background:var(--card);color:var(--ink);border:1.5px solid var(--line);padding:11px 20px;border-radius:14px;
 font-size:13.5px;font-weight:800;cursor:pointer;display:inline-flex;align-items:center;gap:8px;text-decoration:none;box-shadow:var(--shadow)}
.btn-import:hover{border-color:var(--violet);color:var(--violet)}
.btn-save{background:var(--violet);color:#fff;border:none;padding:12px 26px;border-radius:14px;font-size:14px;font-weight:800;
 cursor:pointer;box-shadow:0 10px 22px rgba(139,92,246,.35);transition:transform .1s}
.btn-save:hover{transform:translateY(-1px)}
.btn-cancel{background:none;border:none;font-weight:800;color:var(--ink-3);cursor:pointer;font-size:13.5px;text-decoration:none}
.btn-cancel:hover{color:var(--ink)}
.btn-danger{background:#FDECEF;color:#D6455D;border:1.5px solid #F8CDD6;padding:11px 20px;border-radius:14px;
 font-size:13.5px;font-weight:800;cursor:pointer}
.btn-danger:hover{background:#D6455D;border-color:#D6455D;color:#fff}

/* flash */
.flash{padding:13px 18px;border-radius:16px;margin-bottom:18px;font-weight:700;font-size:13.5px;background:var(--card);box-shadow:var(--shadow)}
.flash.ok{border:1.5px solid #BBE7C9;color:#1D7A43}
.flash.err{border:1.5px solid #F6C6CF;color:#C22E48}
.flash.warn{border:1.5px solid #F5DFA6;color:#8F6A00}

/* ============ STATS ============ */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:20px}
.stat{background:var(--card);border:1.5px solid var(--line);border-radius:var(--r-sm);padding:15px 16px;text-decoration:none;
 display:flex;align-items:center;gap:12px;box-shadow:var(--shadow);transition:transform .12s,border-color .12s;min-width:0}
.stat:hover{transform:translateY(-3px);border-color:#DDD8EC}
.stat .ic{width:42px;height:42px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:18px;flex:none}
.stat .num{font-size:21px;font-weight:800;line-height:1.05;letter-spacing:-.4px}
.stat .lbl{font-size:11px;font-weight:700;color:var(--ink-3);margin-top:2px;white-space:nowrap}
.t1{background:#FFF3D6}.t2{background:#E3F4E6}.t3{background:#E7EFFF}.t4{background:#FDE8F0}.t5{background:var(--violet-soft)}

/* ============ PANELS / GRID ============ */
.dash-grid{display:grid;grid-template-columns:1.75fr 1fr;gap:18px;margin-bottom:24px;align-items:start}
.dash-grid > *{min-width:0}
.rail{display:flex;flex-direction:column;gap:18px}
.panel{background:var(--card);border:1.5px solid var(--line);border-radius:var(--r);padding:20px 22px;box-shadow:var(--shadow);min-width:0;overflow:hidden}
.panel-title{font-size:15.5px;font-weight:800;letter-spacing:-.2px;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.panel-title .see-all{margin-left:auto;font-size:12px;font-weight:800;color:var(--violet);text-decoration:none}
.panel-title .see-all:hover{text-decoration:underline}
.muted{color:var(--ink-3);font-size:13px;font-weight:600}

/* gradient widgets (Taskly Timer/Notes style) */
.widget{border-radius:var(--r);padding:20px 22px;box-shadow:var(--shadow-lg);color:var(--ink);position:relative;overflow:hidden;min-width:0}
.widget.w-violet{background:linear-gradient(150deg,#DACBFF 0%,#C3A8FC 55%,#B491FA 100%)}
.widget.w-pink{background:linear-gradient(150deg,#FBD5E8 0%,#F8BCD9 60%,#F5A9CE 100%)}
.widget .w-title{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:800;margin-bottom:10px}
.widget .w-ic{width:32px;height:32px;border-radius:11px;background:rgba(255,255,255,.5);display:inline-flex;align-items:center;justify-content:center;font-size:15px}
.widget .w-big{font-size:40px;font-weight:800;letter-spacing:-1.5px;line-height:1}
.widget .w-sub{font-size:12px;font-weight:700;opacity:.75;margin-top:6px}
.widget a{text-decoration:none}

/* activity bars */
.bars{display:flex;align-items:flex-end;gap:6px;height:110px}
.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;gap:4px;min-width:0}
.bar{width:100%;max-width:22px;background:#E4DFF2;border-radius:6px;transition:height .3s,background .12s}
.bar-col:hover .bar{background:var(--violet)}
.bar-col.now .bar{background:linear-gradient(180deg,var(--violet),#6D3EF2)}
.bar-lbl{font-size:9.5px;font-weight:800;color:var(--ink-3);text-transform:uppercase}
.bar-col.now .bar-lbl{color:var(--violet)}

/* year chips + color distribution */
.year-chips{display:flex;flex-wrap:wrap;gap:8px}
.year-chip{background:#F6F4FB;border:1.5px solid transparent;border-radius:12px;padding:7px 13px;font-size:12.5px;font-weight:800;
 color:var(--ink-2);text-decoration:none;transition:all .12s}
.year-chip b{color:var(--violet);margin-left:4px}
.year-chip:hover{border-color:var(--violet);color:var(--ink);background:var(--violet-soft)}
.color-dist{display:flex;flex-direction:column;gap:8px}
.cd-row{display:flex;align-items:center;gap:10px;text-decoration:none;font-size:12px;font-weight:800;color:var(--ink-2)}
.cd-name{width:72px}
.cd-track{flex:1;height:10px;background:#F1EEF8;border-radius:6px;overflow:hidden}
.cd-fill{display:block;height:100%;border-radius:6px;min-width:3px;border:none!important}
.cd-num{width:34px;text-align:right;color:var(--ink)}
.storage{margin-top:16px;font-size:12.5px;font-weight:700;color:var(--ink-3);border-top:1.5px dashed var(--line);padding-top:12px}
.storage b{color:var(--ink)}
.file-strip{display:flex;flex-wrap:wrap;gap:9px}

/* ============ RECENT NOTES LIST ============ */
.note-list{display:flex;flex-direction:column}
.nl-row{display:flex;align-items:center;gap:13px;padding:12px 10px;border-bottom:1.5px solid #F3F1F8;text-decoration:none;
 border-radius:14px;transition:background .12s;position:relative;min-width:0}
.nl-row:last-child{border-bottom:none}
.nl-row:hover{background:#F8F6FC}
.nl-row::after{content:'→';position:absolute;right:12px;top:50%;transform:translateY(-50%);font-weight:800;color:var(--violet);opacity:0;transition:opacity .12s}
.nl-row:hover::after{opacity:1}
.nl-row:hover .nl-meta{padding-right:20px}
.nl-bar{width:12px;height:38px;border-radius:6px;flex:none;border:none!important}
.nl-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.nl-title{font-weight:800;font-size:14px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nl-snip{font-size:12px;color:var(--ink-3);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nl-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex:none;transition:padding .12s}
.nl-date{font-size:11px;font-weight:800;color:var(--ink-2);white-space:nowrap;background:#F4F2F9;padding:3px 10px;border-radius:9px}
.nl-atts{display:inline-flex;align-items:center;gap:2px;background:var(--violet-soft);border-radius:9px;padding:2px 8px;font-size:11px}
.nl-atts i{font-style:normal;font-size:12px}
.nl-atts b{color:var(--violet);margin-left:2px}

/* on this day */
.otd-row{display:flex;align-items:center;gap:10px;padding:9px 8px;border-bottom:1.5px solid #F3F1F8;text-decoration:none;min-width:0;border-radius:10px}
.otd-row:last-child{border-bottom:none}
.otd-row:hover{background:#F8F6FC}
.otd-year{font-weight:800;font-size:13px;color:var(--violet);flex:none;background:var(--violet-soft);border-radius:9px;padding:3px 9px}
.otd-title{font-size:12.5px;font-weight:700;color:var(--ink-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.otd-row:hover .otd-title{color:var(--ink)}

/* ============ NOTES PAGE ============ */
.toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:20px}
.color-filter{display:flex;gap:7px;align-items:center;background:var(--card);border:1.5px solid var(--line);
 border-radius:16px;padding:8px 12px;box-shadow:var(--shadow)}
.color-filter a{width:22px;height:22px;border-radius:50%;display:block;border:2px solid rgba(0,0,0,.07);transition:transform .12s}
.color-filter a:hover{transform:scale(1.2)}
.color-filter a.active{border:3px solid var(--ink);transform:scale(1.12)}
.month-jump{padding:11px 14px;border:1.5px solid var(--line);border-radius:14px;font-family:inherit;background:var(--card);
 font-size:13px;font-weight:700;color:var(--ink-2);cursor:pointer;box-shadow:var(--shadow)}
.chip-clear{font-size:12.5px;font-weight:800;color:#C22E48;background:#FDECEF;border:1.5px solid #F6C6CF;padding:8px 14px;border-radius:12px;text-decoration:none}
.datejump{margin-left:auto;display:flex;gap:8px;align-items:center}
.datejump input{padding:10px 12px;border:1.5px solid var(--line);border-radius:14px;font-family:inherit;background:var(--card);box-shadow:var(--shadow);font-size:13px}
.section-title{font-size:16px;font-weight:800;letter-spacing:-.2px;margin:24px 0 13px;display:flex;align-items:center;gap:10px}
.section-title .see-all{margin-left:auto;font-size:12px;font-weight:800;color:var(--violet);text-decoration:none}

.date-divider{display:flex;align-items:center;gap:12px;margin:26px 0 14px;flex-wrap:wrap}
.date-divider .dtxt{font-size:14.5px;font-weight:800;letter-spacing:-.2px}
.date-divider .badge{background:var(--ink);color:#fff;font-size:10.5px;font-weight:800;padding:3px 11px;border-radius:9px;letter-spacing:.4px}
.date-divider .line{flex:1;height:1.5px;min-width:40px;background:var(--line)}
.date-divider .cnt{font-size:11.5px;font-weight:800;color:var(--ink-3)}

/* ============ NOTE CARDS ============ */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.note{--c1:#FFF3D6;--c2:#9A6B00;background:var(--card);border:1.5px solid var(--line);border-radius:var(--r);
 padding:18px 18px 13px;position:relative;box-shadow:var(--shadow);display:flex;flex-direction:column;min-height:150px;
 transition:transform .14s, box-shadow .14s;min-width:0;overflow:hidden}
.note::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--c1),var(--c2))}
.note:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.note .chips{display:flex;gap:7px;align-items:center;margin-bottom:10px;flex-wrap:wrap}
.note .tab{background:var(--c1);color:var(--c2);padding:4px 12px;border-radius:9px;font-size:10.5px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;position:static}
.note .date-chip{background:#F4F2F9;color:var(--ink-2);padding:4px 11px;border-radius:9px;font-size:10.5px;font-weight:800}
.note .pin{margin-left:auto;font-size:14px}
.note h3{font-size:16px;font-weight:800;letter-spacing:-.2px;line-height:1.3;margin-bottom:7px;word-break:break-word}
.note h3 .tlink{text-decoration:none}
.note h3 .tlink:hover{color:var(--violet)}
.note .body{font-size:13px;line-height:1.7;color:var(--ink-2);word-break:break-word;flex:1;max-height:180px;overflow:hidden;position:relative}
.note .body.faded::after{content:'';position:absolute;left:0;right:0;bottom:0;height:36px;background:linear-gradient(transparent,#fff)}
.note-foot{display:flex;align-items:center;gap:8px;margin-top:12px;padding-top:10px;border-top:1.5px solid #F3F1F8}
.note-foot .nd{font-size:11px;font-weight:800;color:var(--ink-3)}
.note-actions{margin-left:auto;display:flex;gap:5px}
.icon-btn{border:1.5px solid var(--line);background:var(--card);width:30px;height:30px;border-radius:10px;cursor:pointer;font-size:13px;
 display:inline-flex;align-items:center;justify-content:center;text-decoration:none;transition:all .12s;color:var(--ink-2)}
.icon-btn:hover{border-color:var(--violet);background:var(--violet-soft)}

/* rich content */
.rich p{margin:0 0 8px}
.rich h1,.rich h2,.rich h3,.rich h4{font-weight:800;letter-spacing:-.2px;margin:13px 0 6px;line-height:1.3;color:var(--ink)}
.rich h2{font-size:18px}.rich h3{font-size:15.5px}
.rich ul,.rich ol{margin:6px 0 10px 22px}
.rich li{margin-bottom:3px}
.rich blockquote{border-left:4px solid var(--violet);margin:10px 0;padding:8px 14px;background:var(--violet-soft);border-radius:0 12px 12px 0;color:var(--ink-2)}
.rich hr{border:none;border-top:1.5px dashed var(--line);margin:14px 0}
.rich a{color:var(--violet);font-weight:700}
.rich table{border-collapse:collapse;margin:10px 0;width:100%;font-size:12.5px}
.rich th,.rich td{border:1.5px solid var(--line);padding:7px 10px;text-align:left;vertical-align:top}
.rich th{background:#F6F4FB;font-weight:800}
.note .body.rich table{font-size:11px}

/* attachments */
.atts{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.att-img{width:62px;height:62px;border-radius:14px;object-fit:cover;border:1.5px solid var(--line);box-shadow:var(--shadow);cursor:zoom-in}
.att-img.big{width:108px;height:108px}
.att-chip{display:inline-flex;align-items:center;gap:7px;background:#F6F4FB;padding:7px 12px;border-radius:12px;
 font-size:12px;font-weight:800;text-decoration:none;border:1.5px solid transparent;max-width:100%;color:var(--ink-2)}
.att-chip:hover{border-color:var(--violet);color:var(--violet)}
.att-chip span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:150px}

/* ============ EMPTY ============ */
.empty{text-align:center;padding:64px 20px;color:var(--ink-3)}
.empty .big{font-size:46px}
.empty h3{font-size:19px;font-weight:800;color:var(--ink);margin:12px 0 5px}
.empty p{font-size:13.5px;font-weight:600}

/* ============ EDITOR PAGE ============ */
.editor-page{max-width:920px;margin:0 auto;background:var(--card);border:1.5px solid var(--line);border-radius:var(--r);
 padding:26px 30px;box-shadow:var(--shadow-lg);min-width:0}
.editor-page label{display:block;font-weight:800;font-size:12.5px;color:var(--ink);margin:18px 0 7px}
.lbl-hint{font-weight:600;color:var(--ink-3)}
.title-input, .editor-page input[type=date]{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:14px;
 font-size:15px;font-family:inherit;background:#FBFAFE}
.title-input:focus, .editor-page input[type=date]:focus{outline:none;border-color:var(--violet);background:#fff}
.row3{display:grid;grid-template-columns:1fr 1.4fr 1fr;gap:16px;align-items:end}

.rt-toolbar{display:flex;flex-wrap:wrap;gap:4px;background:var(--ink);border-radius:16px 16px 0 0;padding:8px 10px;position:sticky;top:8px;z-index:20}
.rt-toolbar button{border:none;background:rgba(255,255,255,.1);color:#fff;min-width:34px;height:32px;padding:0 10px;border-radius:10px;
 cursor:pointer;font-size:13px;font-weight:800;transition:background .1s}
.rt-toolbar button:hover{background:var(--violet)}
.rt-sep{width:1.5px;background:rgba(255,255,255,.18);margin:4px 5px;align-self:stretch}

.rt-editor{min-height:480px;max-height:72vh;overflow-y:auto;background:#FBFAFE;border:1.5px solid var(--line);border-top:none;
 border-radius:0 0 16px 16px;padding:20px 24px;font-size:14.5px;line-height:1.85;font-family:inherit;color:var(--ink)}
.rt-editor:focus{outline:none;border-color:var(--violet);background:#fff}
.rt-editor:empty::before{content:attr(data-placeholder);color:var(--ink-3);pointer-events:none}
.rt-editor p{margin:0 0 8px}
.rt-editor h2,.rt-editor h3{font-weight:800;margin:13px 0 6px;letter-spacing:-.2px}
.rt-editor ul,.rt-editor ol{margin:6px 0 10px 24px}
.rt-editor blockquote{border-left:4px solid var(--violet);margin:10px 0;padding:8px 14px;background:var(--violet-soft);border-radius:0 12px 12px 0}
.rt-editor table{border-collapse:collapse;margin:10px 0;width:100%}
.rt-editor th,.rt-editor td{border:1.5px solid #DDD8EC;padding:7px 10px;min-width:60px}
.rt-editor th{background:#F6F4FB}
.rt-editor hr{border:none;border-top:1.5px dashed var(--line);margin:14px 0}

.color-pick{display:flex;gap:10px;flex-wrap:wrap}
.color-pick label{margin:0;cursor:pointer}
.color-pick input{position:absolute;opacity:0;pointer-events:none}
.color-pick .sw{width:36px;height:36px;border-radius:12px;display:block;border:3px solid transparent;transition:transform .12s;box-shadow:var(--shadow)}
.color-pick input:checked + .sw{border-color:var(--ink);transform:scale(1.12)}
.color-pick input:focus-visible + .sw{outline:3px solid var(--violet)}

.dropzone{border:2px dashed #CFC7E8;border-radius:18px;padding:22px;text-align:center;background:#FBFAFE;cursor:pointer;
 font-size:13px;font-weight:700;color:var(--ink-2);transition:all .12s}
.dropzone:hover{border-color:var(--violet)}
.dropzone.drag{background:var(--violet-soft);border-color:var(--violet)}
.dz-icon{font-size:24px;margin-bottom:4px}
.dz-types{margin-top:8px;font-size:11px;font-weight:800;color:var(--ink-3);letter-spacing:.3px}
#fileList{margin-top:10px;font-size:12.5px;font-weight:700;color:var(--ink-2)}
.fl-head{margin-bottom:8px;color:var(--ink)}
.sel-chips{display:flex;flex-wrap:wrap;gap:8px}
.sel-chip{display:inline-flex;align-items:center;gap:7px;background:var(--card);border:1.5px solid var(--line);border-radius:13px;padding:5px 8px;font-size:12px;font-weight:700;max-width:100%}
.sel-chip img{width:38px;height:38px;border-radius:9px;object-fit:cover;border:1px solid var(--line)}
.sel-chip .sel-ic{font-size:19px}
.sel-chip .sel-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:160px}
.sel-chip small{color:var(--ink-3);font-weight:700;white-space:nowrap}
.sel-chip.too-big{border-color:#F6C6CF;background:#FDF2F4}
.sel-chip.too-big small{color:#C22E48}
.fl-x{border:none;background:#FDECEF;color:#C22E48;width:20px;height:20px;border-radius:50%;cursor:pointer;font-weight:900;line-height:1;flex:none}
.existing-atts{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.ex-att{display:inline-flex;align-items:center;gap:7px;background:var(--card);border:1.5px solid var(--line);border-radius:13px;padding:5px 7px 5px 11px;font-size:12px;font-weight:700}
.ex-att small{color:var(--ink-3)}
.ex-att .ex-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:170px}
.ex-att.ex-img{padding:5px 7px}
.ex-att.ex-img img{width:44px;height:44px;border-radius:10px;object-fit:cover;border:1px solid var(--line);cursor:zoom-in}
.ex-att button{border:none;background:#FDECEF;color:#C22E48;width:20px;height:20px;border-radius:50%;cursor:pointer;font-weight:900;line-height:1;flex:none}
.editor-foot{display:flex;gap:16px;margin-top:26px;align-items:center;flex-wrap:wrap}
.pin-check{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:800;color:var(--ink)}
.pin-check input{accent-color:var(--violet);width:16px;height:16px}

/* ============ NOTE VIEW ============ */
.view-page{--c1:#FFF3D6;--c2:#9A6B00;max-width:920px;margin:0 auto;background:var(--card);border:1.5px solid var(--line);
 border-radius:var(--r);padding:30px 36px 26px;position:relative;box-shadow:var(--shadow-lg);min-width:0;overflow:hidden}
.view-page::before{content:'';position:absolute;top:0;left:0;right:0;height:6px;background:linear-gradient(90deg,var(--c1),var(--c2))}
.view-page .tab{display:inline-flex;background:var(--c1);color:var(--c2);padding:5px 14px;border-radius:10px;font-size:11px;font-weight:800;
 letter-spacing:.8px;text-transform:uppercase;position:static;margin-bottom:14px}
.view-head h1{font-size:24px;font-weight:800;letter-spacing:-.5px;line-height:1.3;word-break:break-word}
.view-meta{font-size:12.5px;font-weight:700;color:var(--ink-3);margin:10px 0 22px}
.view-meta .dot{margin:0 7px}
.view-body{font-size:14.5px;line-height:1.9;word-break:break-word;color:#2B2A33}
.view-atts-title{font-size:14.5px;font-weight:800;margin:24px 0 10px}
.view-actions{display:flex;gap:12px;align-items:center;margin-top:28px;padding-top:18px;border-top:1.5px solid #F3F1F8;flex-wrap:wrap}

/* ============ LOGIN ============ */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--canvas);
 background-image:radial-gradient(circle at 15% 15%, rgba(139,92,246,.16) 0, transparent 40%),
                  radial-gradient(circle at 85% 85%, rgba(244,114,182,.14) 0, transparent 42%)}
.login-card{width:min(410px,92vw);background:var(--card);border:1.5px solid var(--line);border-radius:26px;padding:38px 36px;box-shadow:var(--shadow-lg)}
.login-card .lg-mark{width:52px;height:52px;border-radius:16px;background:linear-gradient(135deg,var(--violet),#6D3EF2);
 display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 14px;box-shadow:0 10px 22px rgba(139,92,246,.4)}
.login-card h1{font-size:22px;font-weight:800;letter-spacing:-.4px;text-align:center;margin-bottom:4px}
.login-card .sub{text-align:center;color:var(--ink-3);font-size:12.5px;font-weight:600;margin-bottom:26px}
.login-card label{display:block;font-weight:800;font-size:12.5px;margin:15px 0 6px}
.login-card input{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:14px;font-size:14.5px;background:#FBFAFE;font-family:inherit}
.login-card input:focus{outline:none;border-color:var(--violet);background:#fff}
.login-card button{width:100%;margin-top:24px;padding:13px;border:none;border-radius:14px;background:var(--ink);color:#fff;
 font-size:15px;font-weight:800;cursor:pointer;box-shadow:0 10px 24px rgba(23,22,28,.3)}
.login-card button:hover{background:var(--violet)}
.login-err{background:#FDECEF;border:1.5px solid #F6C6CF;color:#C22E48;padding:11px 13px;border-radius:13px;font-size:13px;font-weight:700;margin-bottom:12px}
.hint{margin-top:18px;text-align:center;font-size:11.5px;font-weight:600;color:var(--ink-3)}

/* lightbox */
.lightbox{position:fixed;inset:0;background:rgba(17,16,22,.88);z-index:200;display:none;align-items:center;justify-content:center;padding:20px;cursor:zoom-out;backdrop-filter:blur(4px)}
.lightbox.open{display:flex}
.lightbox img{max-width:95vw;max-height:92vh;border-radius:18px;box-shadow:0 20px 80px rgba(0,0,0,.6)}

/* ============ RESPONSIVE ============ */
@media(max-width:1020px){
  .dash-grid{grid-template-columns:1fr}
  .rail{display:grid;grid-template-columns:1fr 1fr;gap:18px}
}
@media(max-width:900px){
  .sidebar{position:fixed;left:0;top:0;bottom:0;transform:translateX(-105%);transition:transform .22s;box-shadow:var(--shadow-lg)}
  .nav-toggle:checked ~ .sidebar{transform:none}
  .nav-toggle:checked ~ .nav-overlay{display:block;position:fixed;inset:0;background:rgba(17,16,22,.4);z-index:55}
  .hamburger{display:flex}
  .row3{grid-template-columns:1fr}
  .topbar{padding:14px 16px 0}
  .content{padding:18px 16px 60px}
}
@media(max-width:720px){
  .rail{grid-template-columns:1fr}
  .user-chip{display:none}
  .grid{grid-template-columns:1fr}
  .editor-page{padding:20px 16px}
  .view-page{padding:24px 20px 22px}
  .rt-toolbar{position:relative;top:0}
  .rt-editor{min-height:340px}
  .datejump{margin-left:0;width:100%}
  .page-title{font-size:22px}
}
@media(prefers-reduced-motion:reduce){ *{transition:none!important} }
