:root {
  --bg:#08101f;
  --panel:#0e1628;
  --panel-2:#111d34;
  --line:#253a61;
  --line-soft:#1c2d4a;
  --text:#f2f5ff;
  --muted:#98a7c8;
  --btn:#1d3155;
  --btn-active:#2f4e84;
  --danger:#7b2f2f;
  --fb:#1877F2;
  --ig:#F56040;
}
*{box-sizing:border-box}
body{margin:0;font-family:Inter,ui-sans-serif,system-ui,sans-serif;background:linear-gradient(180deg,#050d1b,#091426 38%,#060f1b);color:var(--text)}
a{color:#b7cffc}button,input,select,textarea{font:inherit}button{cursor:pointer}img{max-width:100%;display:block}label{display:grid;gap:6px;color:var(--muted)}input,select,textarea{background:#091220;color:var(--text);border:1px solid var(--line);border-radius:12px;padding:11px 12px}textarea{resize:vertical}
.app-shell{max-width:1820px;margin:0 auto;padding:20px}.eyebrow{text-transform:uppercase;letter-spacing:.14em;color:var(--muted);font-size:12px;margin-bottom:8px}.topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px}h1{margin:0;font-size:42px;line-height:1.04}.top-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.tab-btn,.link-btn,.mini-btn,.pager-btn,button[type="submit"],.ghost,.danger,.secondary-btn{background:var(--btn);color:var(--text);border:1px solid var(--line);border-radius:14px;padding:11px 16px;text-decoration:none}.tab-btn.active{background:var(--btn-active)}.ghost{background:transparent}.secondary-btn{background:#172742}.danger{background:var(--danger);border-color:#9f4545}.top-actions .link-btn{display:inline-flex;align-items:center}.small-btn,.mini-tight{padding:8px 12px;border-radius:12px}.tab-panel{display:none}.tab-panel.active{display:block}
.planner-nav{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;margin-bottom:16px}.current-week-block{text-align:center}.current-week-block h2{margin:6px 0 0;font-size:30px}.current-week-label{text-transform:uppercase;letter-spacing:.14em;color:var(--muted);font-size:12px}.current-week-label.current{color:#97ccff}.current-week-label.archived{color:#d6c1a1}.current-week-label.future{color:#9fe0c7}
.legend{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}.legend-chip{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);background:rgba(255,255,255,.03);border-radius:999px;padding:8px 12px;color:var(--muted)}.legend-chip img{width:18px;height:18px;border-radius:999px}
.week-block{--day-col-width:calc((100vw - 120px) / 2);background:var(--panel);border:1px solid var(--line);border-radius:22px;padding:16px;overflow-x:auto}.week-block.focus-current{box-shadow:0 0 0 1px #4471b8 inset}
.days-grid{display:grid;grid-auto-flow:column;grid-auto-columns:var(--day-col-width);gap:16px;min-width:max-content}.day-card{background:rgba(255,255,255,.02);border:1px solid var(--line-soft);border-radius:18px;padding:14px;display:flex;flex-direction:column;gap:12px;min-height:280px;min-width:0}.day-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.day-head strong{font-size:18px;line-height:1.1}.post-stack{display:grid;gap:12px}.empty-day{border:1px dashed #33548a;border-radius:16px;padding:16px;display:grid;gap:12px;min-height:210px;align-content:start}.empty-copy,.muted{color:var(--muted)}.brand-add-row{display:flex;gap:8px;flex-wrap:wrap}
.post-card{display:block;border:2px solid var(--brand-color,#253b63);border-left:5px solid var(--brand-color,#45689b);border-radius:18px;background:linear-gradient(180deg,var(--brand-bg,rgba(69,104,155,.08)),#0c1118 30%,#0c1118);box-shadow:0 0 0 1px var(--brand-glow,rgba(69,104,155,.14)) inset,0 10px 28px rgba(0,0,0,.16);padding:14px;overflow:hidden;transition:opacity .15s ease, filter .15s ease}.post-card.brand-FWI{--brand-color:#2D7D46}.post-card.brand-KF{--brand-color:#C0392B}.post-card.brand-JB{--brand-color:#1A6B8A}.post-card.post-complete{opacity:.54;filter:grayscale(.68)}.post-main{display:grid;gap:12px;min-width:0}.post-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.post-top-meta{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-start;color:var(--muted)}.post-brand-group{display:grid;gap:6px;align-content:start;min-width:0}.post-brand-line{display:flex;gap:8px;align-items:center;min-width:0}.post-brand{font-weight:800;color:var(--text)}.post-cat{font-size:14px}.post-kind-icon{width:55px;height:55px;display:grid;place-items:center;border-radius:14px;background:#1c3153;border:1px solid #4d74b6;color:#f3f8ff;font-size:34px;line-height:1;flex:0 0 auto;opacity:1;box-shadow:0 0 0 1px rgba(255,255,255,.08) inset,0 0 22px rgba(118,160,255,.12)}.brand-logo{height:31px;max-height:31px;max-width:46px;width:auto;object-fit:contain;flex:0 0 auto}.post-excerpt,.copy-block{font-size:15px;line-height:1.55;color:#eef2fb;white-space:pre-wrap}.copy-block{background:#0a1324;border:1px solid #1c2f51;border-radius:14px;padding:12px}
.platforms-row{display:flex;flex-wrap:wrap;gap:8px}.platform-pill{display:inline-flex;align-items:center;gap:8px;border:1px solid #3b6198;border-radius:999px;padding:7px 11px;background:#111b30;color:#eef4ff;font-size:13px}.platform-pill.done{opacity:.48;filter:grayscale(1)}.platform-pill input{margin:0;width:15px;height:15px;accent-color:#8cb2ff}.icon-badge{width:28px;height:28px;border-radius:999px;display:grid;place-items:center;font-weight:900;font-size:14px}.icon-badge.fb{background:rgba(24,119,242,.38);color:#eef6ff;border:1px solid rgba(24,119,242,.96);box-shadow:0 0 0 1px rgba(24,119,242,.28) inset,0 0 18px rgba(24,119,242,.16)}.icon-badge.ig{background:rgba(245,96,64,.34);color:#fff1ec;border:1px solid rgba(245,96,64,.94);box-shadow:0 0 0 1px rgba(245,96,64,.26) inset,0 0 18px rgba(245,96,64,.14)}
.post-actions{display:flex;gap:8px;align-items:center;justify-content:space-between;flex-wrap:wrap}.thumb-strip{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px}.thumb-mini{width:116px;height:88px;object-fit:cover;flex:0 0 auto;border-radius:12px;border:1px solid #274063;background:#08101d}.thumb-button,.preview-large-image,.media-card-image{padding:0;background:transparent;border:none}.thumb-placeholder{display:grid;place-items:center;color:#aab7d6;border:1px solid #274063;background:#08101d;border-radius:14px}.thumb-placeholder.small{width:116px;height:88px;border-radius:12px}.thumb-placeholder span{font-size:13px;border:1px dashed #45618f;border-radius:999px;padding:8px 12px}.thumb-large.thumb-placeholder{min-height:240px}.thumb-large{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:14px;border:1px solid #274063;background:#08101d}
.copy-section{border-radius:14px;padding:10px}.copy-section.fb{border:2px solid rgba(24,119,242,.72);background:linear-gradient(180deg, rgba(24,119,242,.16), rgba(11,19,34,.96));box-shadow:0 0 0 1px rgba(24,119,242,.4) inset, 0 12px 28px rgba(24,119,242,.12)}.copy-section.ig{border:2px solid rgba(245,96,64,.68);background:linear-gradient(180deg, rgba(245,96,64,.14), rgba(11,19,34,.96));box-shadow:0 0 0 1px rgba(245,96,64,.34) inset, 0 12px 28px rgba(245,96,64,.10)}.copy-section .section-head{display:flex;gap:8px;align-items:center;margin-bottom:8px;font-weight:700}
.post-form{padding:18px}.dialog-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}dialog{width:min(1280px,calc(100% - 24px));border:none;border-radius:20px;padding:0;background:#101827;color:var(--text)}dialog::backdrop{background:rgba(0,0,0,.74)}.preview-shell,.media-viewer-shell{padding:18px}.grid.two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.grid .full{grid-column:1 / -1}.compact-top{margin-bottom:14px}
.brand-field-wrap{border:2px solid var(--line);padding:10px;border-radius:16px;background:#0b1322;transition:border-color .12s ease, box-shadow .12s ease, background .12s ease}
.date-gold-row{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.date-field{display:grid;gap:6px;color:var(--muted);flex:1;min-width:160px}
.gold-inline-check{display:flex;align-items:center;gap:6px;color:var(--muted);font-size:14px;white-space:nowrap;cursor:pointer}
.gold-inline-check input{width:15px;height:15px;margin:0;cursor:pointer;accent-color:#8cb2ff;flex:0 0 auto}
.brand-field-wrap,.grid.two > label:not(.brand-field-wrap){display:flex;flex-direction:column;justify-content:flex-end}
.platform-edit-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:14px}.platform-section{border-radius:16px;padding:14px;background:#0b1322}.platform-section.platform-fb{border:2px solid rgba(24,119,242,.72);background:linear-gradient(180deg, rgba(24,119,242,.16), rgba(11,19,34,.96));box-shadow:0 0 0 1px rgba(24,119,242,.4) inset, 0 12px 28px rgba(24,119,242,.12)}.platform-section.platform-ig{border:2px solid rgba(245,96,64,.68);background:linear-gradient(180deg, rgba(245,96,64,.14), rgba(11,19,34,.96));box-shadow:0 0 0 1px rgba(245,96,64,.34) inset, 0 12px 28px rgba(245,96,64,.10)}.platform-heading{display:flex;align-items:center;gap:8px;margin-bottom:10px}.platform-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;align-items:end;margin-bottom:10px}.inline-check{display:flex;align-items:center;gap:8px}.inline-check input{width:16px;height:16px;margin:0}.dialog-actions{display:flex;align-items:center;gap:10px;margin-top:16px}.spacer{flex:1}.hidden{display:none!important}
.media-upload-row{display:grid;gap:8px}.existing-media{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px;margin-top:10px}.media-card{border:1px solid var(--line);border-radius:14px;padding:10px;background:#0b1322;display:grid;gap:10px}.media-card.primary{box-shadow:0 0 0 1px #4d74b9 inset}.media-card img{width:100%;height:140px;object-fit:cover;border-radius:10px;border:1px solid var(--line)}.media-card-actions{display:flex;gap:8px;flex-wrap:wrap}.preview-grid{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:16px;align-items:start}.preview-copy-col{display:grid;gap:12px}.preview-media-col{display:grid;gap:10px}.media-viewer-body{display:grid;place-items:center}.media-viewer-body img{max-height:72vh;width:auto;border-radius:12px;border:1px solid var(--line)}
.admin-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.admin-card,.login-card,.install-card{background:var(--panel);border:1px solid var(--line);border-radius:20px;padding:18px}.stack-form,.maintenance,.install-form,.login-form{display:grid;gap:10px}.diag-list{display:grid;gap:8px;margin-bottom:12px}.diag-list div{display:flex;justify-content:space-between;border-bottom:1px solid #203252;padding-bottom:6px}hr{border:none;border-top:1px solid #22375c;margin:8px 0}.error-box,.success-box{border-radius:14px;padding:12px 14px;margin-bottom:12px}.error-box{background:#3a1717;border:1px solid #7a3131}.success-box{background:#17331c;border:1px solid #285f31}.login-body{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card,.install-card{width:min(720px,100%)}code{background:#091220;padding:2px 6px;border-radius:6px;border:1px solid var(--line)}.password-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}
@media (max-width:1300px){.topbar{flex-direction:column}.planner-nav{grid-template-columns:1fr;justify-items:center}.platform-edit-grid,.admin-grid,.preview-grid{grid-template-columns:1fr}}
@media (max-width:900px){.grid.two,.platform-row{grid-template-columns:1fr}.app-shell{padding:14px}.days-grid{grid-auto-columns:100vw}}

.copy-tools{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0 10px}.copy-tools .small-btn{padding:6px 9px;font-size:12px}

.color-field-row{display:flex;gap:10px;align-items:center}.color-field-row input[type="color"]{width:76px;height:52px;padding:4px;border-radius:12px}.color-field-row input[type="text"]{min-width:120px}

.top-actions-gap{width:14px;display:inline-block}
.action-btn{border:1px solid rgba(255,255,255,.2);padding:10px 16px;border-radius:12px;font-weight:700;color:#fff;background:#22365d}
.import-btn{background:#1d6b3a;border-color:#2e9656}
.export-btn{background:#7b1f2c;border-color:#b54155}
.transfer-shell{min-width:min(980px,92vw);padding:18px 20px 20px;background:#0f1830;color:#eef3ff;border:1px solid rgba(94,129,198,.35);border-radius:18px}
.transfer-text{width:100%;min-height:55vh;background:#091121;color:#eef3ff;border:1px solid rgba(84,116,188,.45);border-radius:14px;padding:14px;font:500 14px/1.45 ui-monospace,SFMono-Regular,Menlo,monospace}
.import-summary{margin-top:12px;border:1px solid rgba(84,116,188,.28);border-radius:14px;padding:12px 14px;background:rgba(13,21,39,.8);max-height:22vh;overflow:auto}
.import-summary ul{margin:.35rem 0 .1rem 1.1rem;padding:0}.error-list{color:#ffb7c2}.ok-list{color:#9de0ad}

.template-btn{background:#284a7a;border-color:#4b77b7}
.planner-toolbar{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:16px}.filter-toggle{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.filter-btn.active{background:var(--btn-active);border-color:#6d90ca;box-shadow:0 0 0 1px rgba(145,178,238,.22) inset}
@media (max-width:1300px){.planner-toolbar{flex-direction:column;align-items:flex-start}}

/* ═══════════════════════════════════════════════════════════════════════════════
   AI FEATURES
   ═══════════════════════════════════════════════════════════════════════════════ */

/* AI buttons in day header */
.ai-btn-row {
  display: flex;
  gap: 6px;
  margin-top: 6px;
  flex-wrap: wrap;
}
.ai-fill-btn, .ai-new-btn {
  font-size: 13px;
  padding: 7px 13px;
  border-radius: 14px;
  border: 2px solid #f5c800;
  background: #f5c800;
  color: #1a1200;
  cursor: pointer;
  font-weight: 700;
  opacity: 0.8;
  transition: background 0.15s, color 0.15s, border-color 0.15s, opacity 0.15s;
  white-space: nowrap;
}
.ai-fill-btn:hover, .ai-new-btn:hover {
  background: #ffe033;
  border-color: #ffe033;
  color: #0f0c00;
  opacity: 1;
}
.ai-fill-btn:disabled, .ai-new-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Brand picker overlay */
.ai-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.5);
  display: flex; align-items: center; justify-content: center;
  z-index: 9000;
}
.ai-brand-picker {
  background: #1e1e2e;
  border-radius: 12px;
  padding: 24px;
  text-align: center;
  min-width: 260px;
}
.ai-brand-picker-title {
  font-size: 15px;
  font-weight: 700;
  margin-bottom: 16px;
  color: #e0e0e0;
}
.ai-brand-picker-btns {
  display: flex;
  gap: 10px;
  justify-content: center;
  margin-bottom: 14px;
}
.ai-brand-option {
  padding: 8px 20px;
  border-radius: 8px;
  border: 2px solid;
  background: transparent;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.15s;
}
.ai-brand-option:hover { opacity: 0.8; }
.ai-cancel-small {
  font-size: 12px;
  color: #888;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
}

/* Proposal Modal */
.ai-proposal-modal {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.6);
  display: flex; align-items: flex-start; justify-content: center;
  z-index: 8000;
  overflow-y: auto;
  padding: 24px 16px;
}
.ai-proposal-inner {
  background: #1a1a2e;
  border-radius: 14px;
  width: 100%;
  max-width: 680px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 8px 40px rgba(0,0,0,0.5);
}
.ai-proposal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid #2a2a45;
  font-size: 15px;
  color: #e0e0e0;
}
.ai-proposal-date {
  font-size: 12px;
  color: #888;
  margin-left: 10px;
  font-weight: 400;
}
.ai-modal-close {
  background: none; border: none;
  color: #888; font-size: 18px;
  cursor: pointer; padding: 2px 6px;
}
.ai-modal-close:hover { color: #fff; }
.ai-proposal-cards {
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  max-height: 70vh;
  overflow-y: auto;
}
.ai-proposal-footer {
  padding: 14px 20px;
  border-top: 1px solid #2a2a45;
  display: flex;
  gap: 10px;
  justify-content: flex-end;
}
.ai-import-approved-btn {
  background: #6c63ff;
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 8px 20px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
}
.ai-import-approved-btn:hover { background: #574fd6; }
.ai-import-approved-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.ai-cancel-btn {
  background: none;
  border: 1px solid #444;
  color: #aaa;
  border-radius: 8px;
  padding: 8px 16px;
  font-size: 13px;
  cursor: pointer;
}
.ai-cancel-btn:hover { border-color: #888; color: #fff; }
.ai-no-posts {
  text-align: center;
  color: #666;
  padding: 24px;
  font-size: 13px;
}

/* Proposal card */
.ai-card {
  background: #12122a;
  border: 1.5px solid #2a2a45;
  border-radius: 10px;
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: opacity 0.2s;
}
.ai-card-approved {
  opacity: 0.55;
  border-color: #2d7d46;
  background: #0d1f13;
}
.ai-card-header {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.ai-card-brand {
  font-size: 12px;
  font-weight: 800;
  background: #6c63ff22;
  color: #a89fff;
  padding: 2px 8px;
  border-radius: 6px;
  letter-spacing: 0.05em;
}
.ai-card-category {
  font-size: 12px;
  color: #ccc;
  font-weight: 600;
}
.ai-card-kind {
  font-size: 11px;
  color: #888;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.ai-card-times {
  font-size: 11px;
  color: #666;
  margin-left: auto;
}
.ai-card-approved-badge {
  font-size: 11px;
  color: #2d7d46;
  font-weight: 700;
  margin-left: auto;
}
.ai-card-reasoning {
  font-size: 12px;
  color: #a0a0c0;
  font-style: italic;
  background: #1e1e35;
  border-left: 3px solid #6c63ff55;
  padding: 8px 10px;
  border-radius: 0 6px 6px 0;
  line-height: 1.5;
}
.ai-card-section-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #666;
  margin-bottom: -6px;
}
.ai-card-copy {
  font-size: 13px;
  color: #ddd;
  line-height: 1.6;
  white-space: pre-wrap;
  background: #1a1a30;
  border-radius: 6px;
  padding: 8px 10px;
  min-height: 48px;
}
.ai-card-editable {
  border: 1px solid #2a2a45;
  cursor: text;
  outline: none;
}
.ai-card-editable:focus {
  border-color: #6c63ff88;
  background: #1e1e38;
}
.ai-card-ig { border-left: 3px solid #e1306c55; }
.ai-card-asset {
  font-size: 12px;
  color: #777;
}
.ai-card-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 4px;
}
.ai-rewrite-row {
  display: flex;
  gap: 6px;
}
.ai-rewrite-input {
  flex: 1;
  background: #12122a;
  border: 1px solid #2a2a45;
  border-radius: 6px;
  padding: 6px 10px;
  color: #ddd;
  font-size: 12px;
}
.ai-rewrite-input:focus { outline: none; border-color: #6c63ff88; }
.ai-rewrite-btn {
  background: #2a2a45;
  border: none;
  border-radius: 6px;
  color: #aaa;
  font-size: 12px;
  padding: 6px 12px;
  cursor: pointer;
  white-space: nowrap;
}
.ai-rewrite-btn:hover { background: #3a3a60; color: #fff; }
.ai-rewrite-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.ai-preset-row {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.ai-preset-btn {
  font-size: 11px;
  padding: 3px 9px;
  border-radius: 10px;
  border: 1px solid #3a3a55;
  background: transparent;
  color: #aaa;
  cursor: pointer;
}
.ai-preset-btn:hover { background: #3a3a55; color: #fff; }
.ai-action-row {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}
.ai-reconceive-btn, .ai-remove-btn, .ai-approve-btn {
  font-size: 12px;
  padding: 6px 14px;
  border-radius: 7px;
  border: none;
  cursor: pointer;
  font-weight: 600;
  transition: opacity 0.15s;
}
.ai-reconceive-btn { background: #2a2a45; color: #aaa; }
.ai-reconceive-btn:hover { background: #3a3a60; color: #fff; }
.ai-reconceive-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.ai-remove-btn { background: #3a1a1a; color: #e07070; }
.ai-remove-btn:hover { background: #5a2020; }
.ai-approve-btn { background: #1a3a25; color: #5cb878; }
.ai-approve-btn:hover { background: #1e4a2e; color: #7de09a; }

/* Living Document Panel */
#ai-doc-trigger {
  position: fixed;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  writing-mode: vertical-rl;
  text-orientation: mixed;
  background: #6c63ff;
  color: #fff;
  border: none;
  border-radius: 8px 0 0 8px;
  padding: 14px 8px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  z-index: 7000;
  letter-spacing: 0.08em;
  box-shadow: -2px 0 12px rgba(108,99,255,0.4);
  transition: background 0.15s;
}
#ai-doc-trigger:hover { background: #574fd6; }

#ai-doc-panel {
  position: fixed;
  right: -420px;
  top: 0; bottom: 0;
  width: 420px;
  background: #13131f;
  border-left: 1px solid #2a2a45;
  display: flex;
  flex-direction: column;
  z-index: 7500;
  transition: right 0.3s ease;
  box-shadow: -4px 0 24px rgba(0,0,0,0.4);
}
#ai-doc-panel.ai-doc-panel-open {
  right: 0;
}
.ai-doc-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 18px;
  border-bottom: 1px solid #2a2a45;
  font-size: 14px;
  color: #e0e0e0;
  flex-shrink: 0;
}
#ai-doc-close {
  background: none; border: none;
  color: #666; font-size: 18px; cursor: pointer; padding: 2px 6px;
}
#ai-doc-close:hover { color: #fff; }

.ai-doc-guidance {
  border-bottom: 1px solid #2a2a45;
  flex-shrink: 0;
}
.ai-doc-guidance summary {
  padding: 10px 18px;
  font-size: 12px;
  color: #888;
  cursor: pointer;
  list-style: none;
  user-select: none;
}
.ai-doc-guidance summary:hover { color: #bbb; }
.ai-doc-guidance-body {
  padding: 0 18px 12px;
  font-size: 12px;
  color: #888;
  line-height: 1.6;
}
.ai-doc-guidance-body ul {
  margin: 4px 0 10px 16px;
  padding: 0;
}
.ai-doc-guidance-body li { margin-bottom: 3px; }
.ai-doc-guidance-body p { margin: 8px 0 2px; }
.ai-doc-guidance-body strong { color: #bbb; }
.ai-doc-guidance-note {
  font-style: italic;
  color: #6c63ff99;
  border-left: 2px solid #6c63ff44;
  padding-left: 8px;
  margin-top: 10px !important;
}

.ai-doc-chat {
  flex: 1;
  overflow-y: auto;
  padding: 14px 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.ai-chat-msg {
  font-size: 13px;
  line-height: 1.6;
  padding: 10px 12px;
  border-radius: 8px;
  max-width: 95%;
  white-space: pre-wrap;
  word-break: break-word;
}
.ai-chat-user {
  background: #6c63ff22;
  color: #c0b8ff;
  align-self: flex-end;
  border-bottom-right-radius: 2px;
}
.ai-chat-assistant {
  background: #1e1e35;
  color: #d0d0e8;
  align-self: flex-start;
  border-bottom-left-radius: 2px;
}

.ai-doc-input-row {
  display: flex;
  gap: 8px;
  padding: 12px 18px;
  border-top: 1px solid #2a2a45;
  flex-shrink: 0;
}
#ai-doc-input {
  flex: 1;
  background: #1a1a2e;
  border: 1px solid #2a2a45;
  border-radius: 8px;
  padding: 8px 10px;
  color: #ddd;
  font-size: 13px;
  resize: none;
  line-height: 1.5;
}
#ai-doc-input:focus { outline: none; border-color: #6c63ff88; }
#ai-doc-send {
  background: #6c63ff;
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 8px 16px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  align-self: flex-end;
}
#ai-doc-send:hover { background: #574fd6; }
#ai-doc-send:disabled { opacity: 0.5; cursor: not-allowed; }

.ai-doc-footer {
  padding: 8px 18px 14px;
  flex-shrink: 0;
}
.ai-doc-small-btn {
  font-size: 11px;
  background: none;
  border: 1px solid #2a2a45;
  color: #666;
  border-radius: 6px;
  padding: 4px 10px;
  cursor: pointer;
}
.ai-doc-small-btn:hover { border-color: #555; color: #aaa; }

@media (max-width: 900px) {
  #ai-doc-panel { width: 100%; right: -100%; }
  .ai-proposal-inner { max-width: 100%; }
}
