@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&family=Inter:wght@400;500&display=swap');

/* ================================================================
   LEONWOOD SOCIAL — v4
   Dark dashboard · Sidebar · Vibrant status colors
================================================================ */

/* ── DARK (default) ─────────────────────────────────────────── */
:root {
  --bg:        #0D0D1A;  --sidebar:   #13131F;  --surface:   #1A1A2E;
  --s2:        #20203A;  --s3:        #28284A;
  --accent:    #5CB88A;  --adim:      rgba(92,184,138,.13);
  --text:      #E4E4F0;  --t2:        #8888A8;  --t3:        #4A4A6A;
  --border:    rgba(255,255,255,.07);  --b2: rgba(255,255,255,.12);
  --shadow:    0 8px 32px rgba(0,0,0,.5);
  --sw: 224px; --r: 10px;
  --font-d: 'Plus Jakarta Sans',-apple-system,sans-serif;
  --font-b: 'Inter',-apple-system,sans-serif;
  /* status */
  --sp-bg:#22223A; --sp-c:#8888A8;
  --sb-bg:#1A2358; --sb-c:#7B9FFF;
  --sf-bg:#0C2E38; --sf-c:#22D3EE;
  --sa-bg:#332000; --sa-c:#F5A623;
  --sg-bg:#0C2A1A; --sg-c:#4CAF82;
  --spo-bg:#330F22;--spo-c:#FF6B8A;
}

/* LIGHT MODE DISABLED
/* ── LIGHT ──────────────────────────────────────────────────── */
[data-theme="light"] {
  --bg:#F0F0F8; --sidebar:#FFFFFF; --surface:#FFFFFF;
  --s2:#F5F5FA; --s3:#EAEAF5;
  --accent:#2A5C45; --adim:rgba(42,92,69,.08);
  --text:#0D0D1A; --t2:#5A5A80; --t3:#A0A0C0;
  --border:rgba(0,0,0,.06); --b2:rgba(0,0,0,.12);
  --shadow:0 4px 20px rgba(0,0,0,.08);
  --sp-bg:#EBEBF5; --sp-c:#6060A0;
  --sb-bg:#ECF0FF; --sb-c:#3344CC;
  --sf-bg:#E8F8FA; --sf-c:#0E7490;
  --sa-bg:#FFF6E8; --sa-c:#B56000;
  --sg-bg:#E8F5EE; --sg-c:#2A5C45;
  --spo-bg:#FFE8F2;--spo-c:#CC2855;
}

/* ── RESET ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box}
html{font-family:var(--font-b);font-size:14px;-webkit-font-smoothing:antialiased}
body{margin:0;display:flex;min-height:100vh;background:var(--bg);color:var(--text);transition:background .2s,color .2s}
a{color:inherit;text-decoration:none}

/* ── SIDEBAR ────────────────────────────────────────────────── */
.sidebar{
  width:var(--sw);background:var(--sidebar);border-right:1px solid var(--border);
  position:fixed;top:0;left:0;height:100vh;z-index:100;
  display:flex;flex-direction:column;overflow:hidden;
}
.sidebar-brand{padding:20px 16px 14px;display:flex;align-items:center;gap:10px}
.brand-mark{
  width:32px;height:32px;background:var(--accent);border-radius:8px;color:#fff;
  font-family:var(--font-d);font-weight:700;font-size:12px;letter-spacing:.04em;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.brand-name{font-family:var(--font-d);font-weight:700;font-size:14px;color:var(--text)}
.sidebar-nav{flex:1;padding:4px 10px;overflow-y:auto}
.nav-item{
  display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:8px;
  color:var(--t2);font-size:13px;transition:all .12s;cursor:pointer;margin-bottom:1px;
}
.nav-item i{font-size:16px;flex-shrink:0}
.nav-item:hover{background:var(--s2);color:var(--text)}
.nav-item.active{background:var(--adim);color:var(--accent);font-weight:500}
.nav-badge{
  margin-left:auto;font-size:10px;font-weight:600;
  background:var(--sa-bg);color:var(--sa-c);padding:2px 7px;border-radius:8px;
}
.nav-divider{height:1px;background:var(--border);margin:8px 0}
.sidebar-footer{
  padding:12px 14px;border-top:1px solid var(--border);
  display:flex;align-items:center;gap:8px;
}
.user-chip{
  width:30px;height:30px;border-radius:50%;background:var(--s2);
  font-size:12px;font-weight:600;color:var(--text);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;border:1px solid var(--b2);
}
.user-meta{flex:1;min-width:0}
.user-meta-name{font-size:12px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-meta-role{font-size:10px;color:var(--t3)}

/* ── ICON BTN ───────────────────────────────────────────────── */
.icon-btn{
  width:30px;height:30px;border-radius:7px;border:1px solid var(--border);
  background:transparent;color:var(--t2);cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-size:14px;
  transition:all .12s;flex-shrink:0;text-decoration:none;
}
.icon-btn:hover{background:var(--s2);color:var(--text)}

/* ── MAIN WRAPPER ───────────────────────────────────────────── */
.main{margin-left:var(--sw);flex:1;display:flex;flex-direction:column;min-height:100vh}

/* ── PAGE HEADER ────────────────────────────────────────────── */
.page-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:24px 28px 18px;gap:16px;flex-wrap:wrap;
}
.page-title{font-family:var(--font-d);font-size:22px;font-weight:700;color:var(--text);margin:0;letter-spacing:-.025em}
.header-actions{display:flex;align-items:center;gap:8px}

/* Month nav */
.month-nav{display:flex;align-items:center;gap:6px}
.month-label{font-family:var(--font-d);font-size:15px;font-weight:600;color:var(--text);min-width:150px;text-align:center}
.today-chip{
  font-size:11px;font-weight:500;color:var(--t2);background:var(--s2);
  border:1px solid var(--border);border-radius:6px;padding:4px 11px;transition:all .12s;cursor:pointer;
}
.today-chip:hover{color:var(--text);background:var(--s3)}

/* ── BUTTONS ────────────────────────────────────────────────── */
.btn-primary{
  display:inline-flex;align-items:center;gap:6px;padding:8px 16px;
  background:var(--accent);color:#fff;border-radius:8px;
  font-size:13px;font-weight:500;border:none;cursor:pointer;transition:opacity .15s;
}
.btn-primary:hover{opacity:.88;color:#fff}
.btn-secondary{
  display:inline-flex;align-items:center;gap:6px;padding:7px 14px;
  background:transparent;color:var(--text);border-radius:8px;
  font-size:13px;font-weight:500;border:1px solid var(--b2);cursor:pointer;transition:all .12s;
}
.btn-secondary:hover{background:var(--s2);color:var(--text)}
.back-btn{display:inline-flex;align-items:center;gap:5px;font-size:13px;color:var(--t2);transition:color .12s}
.back-btn:hover{color:var(--text)}

/* ── FLASH ──────────────────────────────────────────────────── */
.flash-wrap{position:fixed;top:16px;left:50%;transform:translateX(-50%);z-index:500;display:flex;flex-direction:column;gap:6px;min-width:280px;pointer-events:none}
.flash{padding:10px 16px;border-radius:var(--r);font-size:13px;font-weight:500;box-shadow:var(--shadow);pointer-events:auto;animation:fadeIn .2s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
*/
.flash-success{background:var(--sg-bg);color:var(--sg-c);border:1px solid var(--sg-c)}
.flash-danger{background:#330A0A;color:#FF8080;border:1px solid #FF8080}
.flash-warning{background:var(--sa-bg);color:var(--sa-c);border:1px solid var(--sa-c)}
.flash-info{background:var(--sb-bg);color:var(--sb-c);border:1px solid var(--sb-c)}
[data-theme="light"] .flash-danger{background:#FFE8E8;color:#CC2222;border-color:#FCA5A5}

/* ── STATS ROW ──────────────────────────────────────────────── */
.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;padding:0 28px 20px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:18px 20px;display:flex;flex-direction:column;gap:6px}
.stat-label{font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--t3)}
.stat-num{font-family:var(--font-d);font-size:32px;font-weight:700;line-height:1;color:var(--text)}
.stat-sub{font-size:12px;color:var(--t2)}
.stat-num.orange{color:var(--sa-c)}
.stat-num.green{color:var(--sg-c)}

/* ── CALENDAR ───────────────────────────────────────────────── */
.calendar-wrap{flex:1;padding:0 28px 28px;display:flex;flex-direction:column}
.cal-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;flex:1;display:flex;flex-direction:column}
.cal-head{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--border);background:var(--s2)}
.cal-head-cell{padding:10px 8px;text-align:center;font-size:10px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--t3)}
.cal-row{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--border)}
.cal-row:last-child{border-bottom:none}
.cal-cell{min-height:120px;padding:7px;border-right:1px solid var(--border);position:relative;transition:background .1s}
.cal-cell:last-child{border-right:none}
.cal-cell:hover:not(.cal-cell--empty){background:var(--s2)}
.cal-cell--empty{opacity:.35}
.cal-cell--today{background:var(--adim)}
.cal-day{font-size:11px;font-weight:500;color:var(--t3);margin-bottom:4px;line-height:1;display:inline-block}
.cal-day--today{
  width:20px;height:20px;background:var(--accent);color:#fff;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;margin-bottom:3px;
}
.cal-posts{display:flex;flex-direction:column;gap:3px}
.cal-post{
  display:flex;flex-direction:column;gap:2px;padding:5px 7px;
  border-radius:6px;font-size:10px;text-decoration:none;transition:opacity .1s;cursor:pointer;
}
.cal-post:hover{opacity:.82}
.cal-post-row1{display:flex;align-items:center;justify-content:space-between;gap:4px}
.cal-post-status{font-size:9px;font-weight:600;opacity:.85;white-space:nowrap}
.cal-post-title{font-size:11px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}
.cal-post-row2{display:flex;align-items:center;gap:5px;font-size:9px;opacity:.7}
.cal-post--planung{background:var(--sp-bg);color:var(--sp-c)}
.cal-post--in_bearbeitung{background:var(--sb-bg);color:var(--sb-c)}
.cal-post--in_fertigstellung{background:var(--sf-bg);color:var(--sf-c)}
.cal-post--freigabe{background:var(--sa-bg);color:var(--sa-c)}
.cal-post--freigegeben{background:var(--sg-bg);color:var(--sg-c)}
.cal-post--gepostet{background:var(--spo-bg);color:var(--spo-c)}
.cal-legend{display:flex;flex-wrap:wrap;gap:14px;padding:12px 16px;border-top:1px solid var(--border);flex-shrink:0}
.legend-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--t2)}
.legend-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}
.legend-dot.dp{background:var(--sp-c)}.legend-dot.db{background:var(--sb-c)}
.legend-dot.df{background:var(--sf-c)}.legend-dot.da{background:var(--sa-c)}
.legend-dot.dg{background:var(--sg-c)}.legend-dot.dpo{background:var(--spo-c)}

/* ── STATUS PILLS ───────────────────────────────────────────── */
.status-pill{display:inline-flex;align-items:center;font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px;letter-spacing:.02em;flex-shrink:0}
.status-pill.status-planung{background:var(--sp-bg);color:var(--sp-c)}
.status-pill.status-in_bearbeitung{background:var(--sb-bg);color:var(--sb-c)}
.status-pill.status-in_fertigstellung{background:var(--sf-bg);color:var(--sf-c)}
.status-pill.status-freigabe{background:var(--sa-bg);color:var(--sa-c)}
.status-pill.status-freigegeben{background:var(--sg-bg);color:var(--sg-c)}
.status-pill.status-gepostet{background:var(--spo-bg);color:var(--spo-c)}

/* ── POST CARDS (list view) ─────────────────────────────────── */
.posts-list{padding:0 28px 28px}
.posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.post-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:16px;cursor:pointer;transition:all .15s;text-decoration:none;display:flex;flex-direction:column;gap:10px}
.post-card:hover{background:var(--s2);border-color:var(--b2);transform:translateY(-1px)}
.post-card-date{font-family:var(--font-d);font-size:28px;font-weight:700;color:var(--text);line-height:1}
.post-card-month{font-size:11px;color:var(--t3);text-transform:uppercase;letter-spacing:.06em}
.post-card-title{font-size:13px;font-weight:500;color:var(--text);line-height:1.4}
.post-card-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.post-card-indicator{font-size:11px;color:var(--t3);display:flex;align-items:center;gap:3px}
.format-tag{font-size:11px;color:var(--t3);display:flex;align-items:center;gap:3px}

/* ── PAGE BODY (detail/form pages) ──────────────────────────── */
.page-body{padding:0 28px 40px}

/* ── DETAIL PAGE ─────────────────────────────────────────────── */
.post-title-h{font-family:var(--font-d);font-size:22px;font-weight:700;color:var(--text);margin:0 0 10px;letter-spacing:-.02em}
.post-meta-chips{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.meta-chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--t2);background:var(--s2);padding:3px 9px;border-radius:8px;border:1px solid var(--border)}

.detail-layout{display:grid;grid-template-columns:1fr 280px;gap:20px;align-items:start}
.detail-main{display:flex;flex-direction:column;gap:16px}
.detail-side{display:flex;flex-direction:column;gap:12px;position:sticky;top:20px}

/* Section cards */
.psec{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.psec-head{
  display:flex;align-items:center;gap:8px;padding:12px 16px;
  border-bottom:1px solid var(--border);font-size:12px;font-weight:600;color:var(--text);
}
.psec-head i{color:var(--t2);font-size:14px}
.psec-head-right{margin-left:auto;display:flex;align-items:center;gap:8px}
.psec-body{padding:16px}

/* Image grid */
.img-grid{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.img-wrap{position:relative;width:90px;height:90px}
.img-thumb{width:90px;height:90px;object-fit:cover;border-radius:8px;border:1px solid var(--border);display:block}
.img-del{
  position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;
  background:rgba(0,0,0,.6);color:#fff;border:none;cursor:pointer;
  font-size:12px;display:flex;align-items:center;justify-content:center;transition:background .1s;
}
.img-del:hover{background:rgba(200,30,30,.85)}

/* Upload zone */
.upload-zone{
  border:1.5px dashed var(--b2);border-radius:var(--r);padding:16px;
  background:var(--s2);transition:border-color .15s;display:flex;flex-direction:column;gap:10px;
}
.upload-zone:hover{border-color:var(--accent)}
.upload-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.upload-label{
  display:inline-flex;align-items:center;gap:6px;padding:7px 14px;
  background:var(--s3);border:1px solid var(--b2);border-radius:8px;
  font-size:12px;font-weight:500;cursor:pointer;color:var(--text);transition:all .12s;flex-shrink:0;
}
.upload-label:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.upload-hint{font-size:11px;color:var(--t3)}
.upload-count{font-size:11px;color:var(--accent);font-weight:500;margin-top:2px;min-height:16px}

/* Text fields */
.field-label{font-size:11px;font-weight:600;color:var(--t2);margin-bottom:6px;display:block;letter-spacing:.03em;text-transform:uppercase}
.field-input,.field-select,.field-textarea{
  width:100%;padding:9px 12px;background:var(--s2);border:1px solid var(--b2);
  color:var(--text);border-radius:8px;font-size:13px;font-family:var(--font-b);
  transition:border-color .12s;display:block;
}
.field-input:focus,.field-select:focus,.field-textarea:focus{
  outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--adim);
}
.field-textarea{resize:vertical;min-height:110px;line-height:1.6}
.field-group{margin-bottom:14px}

/* Status buttons */
.status-btn-list{display:flex;flex-direction:column;gap:6px}
.status-btn{
  display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;
  border:1px solid var(--border);cursor:pointer;background:transparent;
  font-size:12px;color:var(--text);font-family:var(--font-b);
  width:100%;text-align:left;transition:all .12s;
}
.status-btn:hover{background:var(--s2);border-color:var(--b2)}
.status-btn.current{border-color:var(--accent);background:var(--adim)}
.status-dot-sm{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.status-dot-sm.dp{background:var(--sp-c)}.status-dot-sm.db{background:var(--sb-c)}
.status-dot-sm.df{background:var(--sf-c)}.status-dot-sm.da{background:var(--sa-c)}
.status-dot-sm.dg{background:var(--sg-c)}.status-dot-sm.dpo{background:var(--spo-c)}

/* Info table */
.info-table{width:100%;border-collapse:collapse}
.info-table tr{border-bottom:1px solid var(--border)}
.info-table tr:last-child{border-bottom:none}
.info-table td{padding:7px 0;font-size:12px;vertical-align:middle}
.info-table td:first-child{color:var(--t3);width:70px}
.info-table td:last-child{color:var(--text);font-weight:500;text-align:right}

/* ── NEW POST FORM ───────────────────────────────────────────── */
.form-wrap{max-width:520px}
.format-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.format-radio{display:none}
.format-label{
  display:flex;align-items:center;justify-content:center;gap:7px;
  padding:10px;border:1.5px solid var(--b2);border-radius:8px;
  cursor:pointer;font-size:13px;color:var(--t2);transition:all .12s;background:var(--s2);
}
.format-label:hover{border-color:var(--accent);color:var(--accent)}
.format-radio:checked + .format-label{border-color:var(--accent);color:var(--accent);background:var(--adim);font-weight:500}

/* ── LOGIN ──────────────────────────────────────────────────── */
.login-page{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:36px;box-shadow:var(--shadow)}
.login-mark{width:44px;height:44px;background:var(--accent);border-radius:10px;color:#fff;font-family:var(--font-d);font-weight:700;font-size:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.login-title{font-family:var(--font-d);font-size:20px;font-weight:700;color:var(--text);text-align:center;margin:0 0 4px}
.login-sub{font-size:13px;color:var(--t2);text-align:center;margin:0 0 28px}
.login-btn{width:100%;padding:11px;background:var(--accent);color:#fff;border-radius:8px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s;font-family:var(--font-d)}
.login-btn:hover{opacity:.88}

/* ── BOOTSTRAP OVERRIDES ────────────────────────────────────── */
.navbar{display:none!important}
.card{background:var(--surface)!important;border-color:var(--border)!important;border-radius:var(--r)!important}
.card-header,.card-body{background:var(--surface)!important;border-color:var(--border)!important}
.form-control,.form-select{background:var(--s2)!important;border-color:var(--b2)!important;color:var(--text)!important;border-radius:8px;font-size:13px}
.form-control:focus,.form-select:focus{background:var(--s2)!important;border-color:var(--accent)!important;color:var(--text)!important;box-shadow:0 0 0 3px var(--adim)!important}
.form-label{font-size:13px;font-weight:500;color:var(--text)}
.form-text{color:var(--t3)!important}
.btn-dark{background:var(--accent)!important;border-color:var(--accent)!important;border-radius:8px!important;font-size:13px!important;font-weight:500!important}
.btn-dark:hover{opacity:.88!important}
.btn-outline-dark{color:var(--text)!important;border-color:var(--b2)!important;border-radius:8px!important;font-size:13px!important}
.btn-outline-dark:hover{background:var(--s2)!important}
.btn-outline-secondary{color:var(--t2)!important;border-color:var(--border)!important;border-radius:8px!important}
.btn-outline-secondary:hover{background:var(--s2)!important}
.btn-success{background:var(--sg-c)!important;border-color:var(--sg-c)!important;color:#fff!important;border-radius:8px!important}
.alert{border-radius:var(--r)!important;font-size:13px;background:var(--s2)!important;border-color:var(--b2)!important;color:var(--text)!important}
.badge{border-radius:8px!important}
.table{color:var(--text)}.table td,.table th{border-color:var(--border);color:var(--text)}
.text-muted{color:var(--t2)!important}
.dropdown-menu{background:var(--surface);border-color:var(--border);border-radius:var(--r);box-shadow:var(--shadow)}
.dropdown-item{color:var(--text);font-size:13px}.dropdown-item:hover{background:var(--s2)}

/* ── MOBILE ──────────────────────────────────────────────────── */
@media(max-width:768px){
  :root{--sw:0px}
  .sidebar{transform:translateX(-100%);transition:transform .25s}
  .sidebar.open{transform:translateX(0);--sw:220px}
  .main{margin-left:0}
  .page-header,.stats-row,.calendar-wrap,.posts-list,.page-body{padding-left:16px;padding-right:16px}
  .stats-row{grid-template-columns:1fr 1fr}
  .cal-cell{min-height:70px}
  .detail-layout{grid-template-columns:1fr}
  .detail-side{position:static}
  .cal-post-row2{display:none}
  .page-title{font-size:18px}
}

/* ── CALENDAR WORKSPACE (2-Spalten) ─────────────────────────── */
.cal-workspace {
  flex:1; padding:0 28px 28px;
  display:grid; grid-template-columns:1fr 268px; gap:16px; align-items:start;
}
.cal-left { display:flex; flex-direction:column; }
.cal-right {
  display:flex; flex-direction:column; gap:12px;
  position:sticky; top:20px;
  max-height:calc(100vh - 220px); overflow:hidden;
}

/* Right panel sections */
.rpanel { background:var(--surface); border:1px solid var(--border); border-radius:var(--r); overflow:hidden; display:flex; flex-direction:column; }
.rpanel-head {
  padding:10px 14px; border-bottom:1px solid var(--border);
  font-size:11px; font-weight:600; color:var(--text);
  display:flex; align-items:center; gap:7px; flex-shrink:0;
}
.rpanel-head i { color:var(--t2); font-size:13px; }
.rpanel-head-right { margin-left:auto; }
.rpanel-body { padding:10px; overflow-y:auto; }
.rpanel-scroll { overflow-y:auto; }

/* Freigabe items */
.frei-item {
  display:flex; align-items:center; gap:10px; padding:8px 10px;
  border-radius:8px; cursor:pointer; transition:background .1s; margin-bottom:3px;
}
.frei-item:hover,.frei-item.active { background:var(--s2); }
.frei-dot { width:8px; height:8px; border-radius:50%; background:var(--sa-c); flex-shrink:0; }
.frei-info { flex:1; min-width:0; }
.frei-title { font-size:12px; font-weight:500; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.frei-meta  { font-size:10px; color:var(--t3); margin-top:1px; }
.frei-date  { font-size:11px; color:var(--t3); flex-shrink:0; }
.frei-empty { font-size:12px; color:var(--t3); padding:8px 10px; }

/* Detail panel */
.dp-header { padding:12px 14px; border-bottom:1px solid var(--border); flex-shrink:0; }
.dp-title { font-family:var(--font-d); font-size:14px; font-weight:700; color:var(--text); margin:0 0 6px; line-height:1.3; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.dp-chips { display:flex; flex-wrap:wrap; gap:5px; }
.dp-chip { font-size:10px; padding:2px 7px; border-radius:6px; background:var(--s2); color:var(--t2); border:1px solid var(--border); display:flex; align-items:center; gap:3px; }
.dp-body { flex:1; overflow-y:auto; padding:12px 14px; display:flex; flex-direction:column; gap:10px; }
.dp-section-label { font-size:9px; font-weight:600; letter-spacing:.07em; text-transform:uppercase; color:var(--t3); margin-bottom:5px; }
.dp-img-row { display:flex; flex-wrap:wrap; gap:6px; }
.dp-img { width:54px; height:54px; object-fit:cover; border-radius:6px; border:1px solid var(--border); }
.dp-no-content { font-size:11px; color:var(--t3); font-style:italic; }
.dp-caption { font-size:12px; color:var(--t2); line-height:1.6; display:-webkit-box; -webkit-line-clamp:4; -webkit-box-orient:vertical; overflow:hidden; }
.dp-hashtags { font-size:10px; color:var(--t3); }
.dp-footer { padding:10px 14px; border-top:1px solid var(--border); display:flex; flex-direction:column; gap:6px; flex-shrink:0; }
.dp-status-grid { display:grid; grid-template-columns:1fr 1fr 1fr; gap:3px; }
.dp-status-btn {
  font-size:9px; font-weight:600; padding:5px 4px; border-radius:6px;
  border:1px solid var(--border); cursor:pointer; background:transparent;
  color:var(--t2); transition:all .12s; font-family:var(--font-b);
  display:flex; align-items:center; justify-content:center; gap:3px; text-align:center;
  line-height:1.2;
}
.dp-status-btn:hover { background:var(--s2); color:var(--text); }
.dp-status-btn.dp-cur { border-color:var(--accent); background:var(--adim); color:var(--accent); }
.dp-status-btn.dp-loading { opacity:.5; pointer-events:none; }
.dp-edit-btn {
  display:flex; align-items:center; justify-content:center; gap:6px;
  padding:8px; background:var(--accent); color:#fff; border-radius:8px;
  font-size:12px; font-weight:500; border:none; cursor:pointer; text-decoration:none;
  transition:opacity .15s; width:100%;
}
.dp-edit-btn:hover { opacity:.88; color:#fff; }

/* Selected cal-post ring */
.cal-post.selected { outline:2px solid var(--accent); outline-offset:1px; }

@media(max-width:1024px){
  .cal-workspace { grid-template-columns:1fr; }
  .cal-right { position:static; max-height:none; }
}
[data-theme="light"] { --logo-filter: invert(1) brightness(0.3); }
