/* Salesedge Dashboard - Shared Stylesheet
 * Innehåller alla gemensamma stilar för:
 * index.html, sales.html, content.html, inbox.html, history.html
 *
 * Brand: cream #F3E4D0 / teal #0D393A / gold #ECAA56
 */

:root {
  --cream: #F3E4D0;
  --cream-dk: #E8D2B8;
  --teal: #0D393A;
  --teal-lt: #174F50;
  --teal-xs: rgba(13,57,58,.06);
  --taupe: #A1907A;
  --gold: #ECAA56;
  --gold-lt: rgba(236,170,86,.15);
  --green: #22c55e;
  --red: #ef4444;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;overflow:hidden;}
body{background:var(--cream);color:var(--teal);font-family:'Inter',sans-serif;display:flex;}

/* SIDEBAR */
.sidebar{
  width:220px;flex-shrink:0;background:var(--teal);
  display:flex;flex-direction:column;
  padding:0;height:100vh;height:100dvh;position:relative;
  transition:width 0.22s ease;
}

/* Sidebar toggle (collapse/expand) - desktop only */
.sidebar-toggle{
  position:absolute;right:-13px;top:64px;
  width:26px;height:26px;border-radius:50%;
  background:var(--cream);border:2px solid var(--teal);
  color:var(--teal);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  z-index:5;padding:0;
  box-shadow:0 1px 3px rgba(0,0,0,.1);
}
.sidebar-toggle:hover{background:var(--gold);}
.sidebar-toggle svg{width:12px;height:12px;transition:transform 0.22s;}
.sidebar.collapsed .sidebar-toggle svg{transform:rotate(180deg);}

/* Collapsed state - desktop */
.sidebar.collapsed{width:64px;}
.sidebar.collapsed .sidebar-logo{padding:20px 8px 16px;display:flex;justify-content:center;}
.sidebar.collapsed .sidebar-logo img{height:24px;}
.sidebar.collapsed .sidebar-sub{display:none;}
.sidebar.collapsed .nav-section{
  visibility:hidden;height:0;padding:8px 0 0;overflow:hidden;
}
.sidebar.collapsed .nav-item{
  font-size:0;padding:12px 0;gap:0;justify-content:center;
  border-left:none;border-right:2px solid transparent;
}
.sidebar.collapsed .nav-item svg{width:18px;height:18px;}
.sidebar.collapsed .nav-item.active{border-right-color:var(--gold);}
.sidebar.collapsed .nav-badge{
  position:absolute;top:4px;right:6px;
  font-size:8px;min-width:14px;padding:0 4px;margin:0;
  border-radius:8px;line-height:1.4;
}
.sidebar.collapsed .sidebar-footer{padding:14px 8px calc(14px + env(safe-area-inset-bottom));}
.sidebar.collapsed .sidebar-user{justify-content:center;gap:0;}
.sidebar.collapsed .sidebar-user>div:last-child{display:none;}

@media (max-width:700px){.sidebar-toggle{display:none;}}
.sidebar-logo{
  padding:24px 20px 20px;border-bottom:1px solid rgba(243,228,208,.08);
}
.sidebar-logo img{height:36px;filter:brightness(0) invert(1);opacity:.85;}
.sidebar-sub{
  font-family:'Inter',sans-serif;font-size:9px;font-weight:600;
  letter-spacing:2px;text-transform:uppercase;color:rgba(243,228,208,.3);
  margin-top:6px;
}
.sidebar-nav{padding:16px 0;flex:1;}
.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 20px;cursor:pointer;
  font-size:12px;font-weight:500;color:rgba(243,228,208,.5);
  transition:background .15s,color .15s;position:relative;
  border-left:2px solid transparent;
}
.nav-item:hover{color:var(--cream);background:rgba(243,228,208,.05);}
.nav-item.active{color:var(--cream);border-left-color:var(--gold);background:rgba(243,228,208,.07);}
.nav-item svg{width:15px;height:15px;flex-shrink:0;opacity:.7;}
.nav-item.active svg{opacity:1;}
.nav-badge{
  margin-left:auto;background:var(--gold);color:var(--teal);
  font-size:9px;font-weight:800;padding:1px 6px;border-radius:10px;
}
.nav-section{
  font-size:8px;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  color:rgba(243,228,208,.2);padding:16px 20px 6px;
}
.sidebar-footer{
  padding:16px 20px calc(16px + env(safe-area-inset-bottom));
  border-top:1px solid rgba(243,228,208,.08);
}
.sidebar-user{display:flex;align-items:center;gap:10px;}
.user-avatar{
  width:32px;height:32px;border-radius:50%;background:var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:800;color:var(--teal);flex-shrink:0;
  overflow:hidden;
}
.user-avatar img{width:100%;height:100%;object-fit:cover;display:block;}

/* ─── MODAL (delas av tasks, CRM, m.fl.) ─────────────── */
.modal-backdrop{
  display:none;position:fixed;inset:0;background:rgba(13,57,58,.55);
  z-index:1000;align-items:center;justify-content:center;padding:20px;
}
.modal-backdrop.show{display:flex;}
.modal{
  background:var(--cream);border:1px solid rgba(13,57,58,.1);
  padding:28px;width:100%;max-width:520px;
  max-height:90vh;overflow-y:auto;position:relative;
}
.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px;}
.modal-title{font-family:'Cormorant',serif;font-size:24px;font-weight:600;color:var(--teal);}
.modal-title em{font-style:italic;color:var(--gold);}
.modal-close{
  background:transparent;border:none;color:var(--taupe);font-size:22px;
  cursor:pointer;padding:0 6px;line-height:1;
}
.modal-close:hover{color:var(--teal);}

/* ─── SIDE PANEL (slide-out från höger för CRM-detaljer) ─ */
.side-panel-backdrop{
  display:none;position:fixed;inset:0;background:rgba(13,57,58,.45);
  z-index:1000;justify-content:flex-end;
}
.side-panel-backdrop.show{display:flex;animation:fadeIn .18s ease-out;}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
.side-panel{
  background:var(--cream);border-left:1px solid rgba(13,57,58,.12);
  width:min(680px, 88vw);height:100vh;
  overflow-y:auto;padding:32px 36px 28px;
  box-shadow:-12px 0 36px rgba(13,57,58,.22);
  animation:slideInRight .22s ease-out;
  position:relative;
}
@keyframes slideInRight{
  from{transform:translateX(28px);opacity:.4;}
  to{transform:translateX(0);opacity:1;}
}
@media(max-width:780px){
  .side-panel{width:100vw;border-left:none;padding:24px 20px;}
}
.side-panel-header{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:24px;padding-bottom:16px;
  border-bottom:1px solid rgba(13,57,58,.08);
}
.side-panel-title{
  font-family:'Cormorant',serif;font-size:26px;font-weight:600;color:var(--teal);
}
.side-panel-title em{font-style:italic;color:var(--gold);}
.side-panel-close{
  background:transparent;border:none;color:var(--taupe);font-size:24px;
  cursor:pointer;padding:4px 10px;line-height:1;border-radius:4px;
}
.side-panel-close:hover{color:var(--teal);background:rgba(13,57,58,.06);}
.side-panel-actions{
  display:flex;gap:10px;margin-top:24px;padding-top:20px;
  border-top:1px solid rgba(13,57,58,.08);
}
.side-panel-actions .btn{flex:1;justify-content:center;}

.form-field{margin-bottom:16px;}
.form-label{
  display:block;font-size:9px;font-weight:700;letter-spacing:2px;
  text-transform:uppercase;color:var(--taupe);margin-bottom:6px;
}
.form-input,.form-textarea,.form-select{
  width:100%;background:white;border:1px solid rgba(13,57,58,.15);
  padding:10px 12px;font-size:14px;font-family:'Inter',sans-serif;
  color:var(--teal);outline:none;transition:border-color .15s;
}
.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--gold);}
.form-textarea{resize:vertical;min-height:80px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.modal-actions{display:flex;gap:10px;margin-top:24px;}
.modal-actions .btn{flex:1;justify-content:center;}

/* ─── NOTES-SEKTION (i CRM-modaler) ──────────────────── */
.notes-section{
  margin-top:24px;padding-top:20px;
  border-top:1px solid rgba(13,57,58,.1);
}
.notes-section-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:14px;
}
.notes-section-title{
  font-size:9px;font-weight:700;letter-spacing:2px;
  text-transform:uppercase;color:var(--taupe);
}
.notes-add-row{
  display:flex;gap:8px;align-items:flex-start;margin-bottom:14px;
}
.notes-add-row textarea{
  flex:1;background:white;border:1px solid rgba(13,57,58,.15);
  padding:10px 12px;font-size:13px;font-family:'Inter',sans-serif;
  color:var(--teal);outline:none;resize:vertical;min-height:60px;
  line-height:1.5;
}
.notes-add-row textarea:focus{border-color:var(--gold);}
.notes-add-controls{display:flex;flex-direction:column;gap:6px;}
.notes-add-controls .btn{justify-content:center;}
.notes-add-controls .btn-sm{padding:6px 10px;font-size:11px;}
.notes-status{
  font-size:10px;color:var(--taupe);min-height:14px;
  margin:0 0 8px 0;font-style:italic;
}
.notes-status.error{color:var(--red);font-style:normal;}
.notes-status.success{color:var(--green);font-style:normal;}
.notes-timeline{
  display:flex;flex-direction:column;gap:8px;
  max-height:340px;overflow-y:auto;padding-right:6px;
}
.note-item{
  background:white;border:1px solid rgba(13,57,58,.08);
  padding:12px 14px;position:relative;
}
.note-item::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:rgba(13,57,58,.15);
}
.note-item.source-voice::before{background:var(--gold);}
.note-item.source-mejl::before{background:var(--teal);}
.note-item.source-mote::before{background:var(--green);}
.note-text{
  font-size:13px;color:var(--teal);line-height:1.55;
  white-space:pre-wrap;word-wrap:break-word;
}
.note-meta{
  font-size:10px;color:var(--taupe);
  margin-top:6px;display:flex;gap:8px;align-items:center;
}
.note-meta-badge{
  padding:1px 6px;border-radius:2px;
  font-size:9px;font-weight:600;letter-spacing:0.5px;text-transform:uppercase;
}
.note-meta-badge.text{background:rgba(13,57,58,.08);color:var(--taupe);}
.note-meta-badge.voice{background:rgba(236,170,86,.15);color:#b8841f;}
.note-meta-badge.mejl{background:rgba(13,57,58,.1);color:var(--teal);}
.note-meta-badge.mote{background:rgba(34,197,94,.12);color:var(--green);}
.note-meta-badge.manual{background:rgba(13,57,58,.05);color:var(--taupe);}
.note-empty{
  text-align:center;padding:24px;color:var(--taupe);
  font-size:12px;font-style:italic;
}
.note-del-btn{
  background:transparent;border:none;color:rgba(13,57,58,.3);
  cursor:pointer;padding:2px 6px;font-size:14px;line-height:1;
  margin-left:auto;
}
.note-del-btn:hover{color:var(--red);}

/* ─── MINI MIC-KNAPP (för fält i modaler/detail-panel) ─── */
.mic-btn-mini{
  width:28px;height:28px;border-radius:50%;
  background:var(--cream);border:1.5px solid rgba(13,57,58,.2);
  cursor:pointer;display:inline-flex;align-items:center;justify-content:center;
  color:var(--teal);transition:all .15s;flex-shrink:0;padding:0;
  -webkit-tap-highlight-color:transparent;
}
.mic-btn-mini:hover:not(:disabled){background:var(--gold-lt);border-color:var(--gold);}
.mic-btn-mini:disabled{opacity:0.4;cursor:not-allowed;}
.mic-btn-mini svg{width:13px;height:13px;}
.mic-btn-mini .mic-icon-stop{display:none;}
.mic-btn-mini.recording{
  background:var(--red);border-color:var(--red);color:white;
  animation:micPulseMini 1.1s infinite;
}
.mic-btn-mini.recording .mic-icon-idle{display:none;}
.mic-btn-mini.recording .mic-icon-stop{display:block;}
.mic-btn-mini.uploading{background:var(--gold);border-color:var(--gold);}
.mic-btn-mini .mic-spinner{
  display:none;width:13px;height:13px;
  border:2px solid rgba(13,57,58,.2);border-top-color:var(--teal);
  border-radius:50%;animation:spin 0.8s linear infinite;
}
.mic-btn-mini.uploading .mic-icon-idle,
.mic-btn-mini.uploading .mic-icon-stop{display:none;}
.mic-btn-mini.uploading .mic-spinner{display:block;}
@keyframes micPulseMini{
  0%,100%{box-shadow:0 0 0 3px rgba(239,68,68,.15);}
  50%{box-shadow:0 0 0 7px rgba(239,68,68,.05);}
}
.mic-status-inline{
  font-size:10px;color:var(--taupe);margin-top:4px;
  font-style:italic;min-height:13px;
}
.mic-status-inline.error{color:var(--red);font-style:normal;}
.mic-status-inline.success{color:var(--green);font-style:normal;}
.user-name{font-size:12px;font-weight:600;color:var(--cream);}
.user-role{font-size:10px;color:rgba(243,228,208,.35);}

/* MAIN */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;}
.topbar{
  height:56px;flex-shrink:0;background:var(--cream);
  border-bottom:1px solid rgba(13,57,58,.08);
  display:flex;align-items:center;padding:0 28px;gap:16px;
}
.topbar-title{
  font-family:'Cormorant',serif;font-size:20px;font-weight:600;
  color:var(--teal);
}
.topbar-sub{font-size:11px;color:var(--taupe);margin-left:4px;}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:12px;}
.btn{
  font-family:'Inter',sans-serif;font-size:11px;font-weight:600;
  letter-spacing:1px;text-transform:uppercase;
  padding:0 16px;height:34px;display:inline-flex;align-items:center;
  cursor:pointer;border:none;transition:all .15s;gap:6px;
}
.btn-primary{background:var(--teal);color:var(--cream);}
.btn-primary:hover{background:var(--teal-lt);}
.btn-outline{background:transparent;color:var(--teal);border:1.5px solid rgba(13,57,58,.2);}
.btn-outline:hover{border-color:var(--teal);}
.btn-gold{background:var(--gold);color:var(--teal);}
.btn-gold:hover{background:#d4923c;}
.btn-sm{height:28px;font-size:10px;padding:0 12px;}

.content{flex:1;overflow-y:auto;padding:24px 28px;}

/* VIEWS */
.view{display:none;}
.view.active{display:block;}

/* PENDING VIEW */
.pending-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:20px;
}
.pending-header h2{
  font-family:'Cormorant',serif;font-size:26px;font-weight:600;color:var(--teal);
}
.pending-header h2 em{font-style:italic;color:var(--gold);}
.filter-row{display:flex;gap:6px;margin-bottom:16px;}
.filter-chip{
  font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;
  padding:4px 12px;cursor:pointer;border:1.5px solid rgba(13,57,58,.15);
  color:rgba(13,57,58,.5);background:transparent;transition:all .15s;
}
.filter-chip.active{border-color:var(--teal);color:var(--teal);background:var(--teal-xs);}
.filter-chip:hover{border-color:var(--teal);}

.pending-list{display:flex;flex-direction:column;gap:3px;}
.pending-card{
  background:white;border:1px solid rgba(13,57,58,.07);
  padding:16px 20px;cursor:pointer;
  display:flex;align-items:center;gap:16px;
  transition:border-color .15s,box-shadow .15s;
  position:relative;overflow:hidden;
}
.pending-card::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:transparent;transition:background .15s;
}
.pending-card:hover{border-color:rgba(13,57,58,.15);box-shadow:0 2px 12px rgba(13,57,58,.05);}
.pending-card:hover::before{background:var(--gold);}
.pending-card.selected{border-color:var(--teal);box-shadow:0 0 0 1px var(--teal);}
.pending-card.selected::before{background:var(--teal);}
.card-type-icon{
  width:38px;height:38px;border-radius:2px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;font-size:16px;
}
.type-mote{background:rgba(13,57,58,.08);}
.type-content{background:var(--gold-lt);}
.type-forslag{background:rgba(34,197,94,.1);}
.card-info{flex:1;min-width:0;}
.card-title{font-size:13px;font-weight:600;color:var(--teal);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.card-meta{font-size:11px;color:var(--taupe);}
.card-status{
  font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  padding:3px 10px;flex-shrink:0;
}
.status-pending{background:var(--gold-lt);color:#9a6c2a;}
.status-approved{background:rgba(34,197,94,.1);color:#166534;}
.status-rejected{background:rgba(239,68,68,.1);color:#991b1b;}
.card-outputs{
  display:flex;gap:4px;flex-shrink:0;
}
.output-chip{
  font-size:9px;font-weight:600;letter-spacing:.5px;
  padding:2px 7px;background:var(--teal-xs);color:rgba(13,57,58,.5);
}

/* DETAIL PANEL */
.detail-panel{
  position:fixed;right:0;top:0;bottom:0;width:520px;
  background:var(--cream);border-left:1px solid rgba(13,57,58,.1);
  display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform .25s ease;
  z-index:100;
}
.detail-panel.open{transform:translateX(0);}
.detail-header{
  padding:18px 24px;border-bottom:1px solid rgba(13,57,58,.08);
  display:flex;align-items:center;gap:12px;flex-shrink:0;
}
.detail-close{
  width:32px;height:32px;border:1.5px solid rgba(13,57,58,.2);
  background:white;cursor:pointer;display:flex;align-items:center;justify-content:center;
  font-size:16px;color:var(--teal);transition:all .15s;font-weight:300;
}
.detail-close:hover{border-color:var(--teal);background:var(--teal);color:var(--cream);}
.detail-title{font-family:'Cormorant',serif;font-size:18px;font-weight:600;flex:1;}
.detail-body{flex:1;overflow-y:auto;padding:20px 24px;}
.output-section{margin-bottom:20px;}
.output-label{
  font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  color:var(--taupe);margin-bottom:8px;display:flex;align-items:center;gap:8px;
}
.output-label::after{content:'';flex:1;height:1px;background:rgba(13,57,58,.08);}
.output-text{
  background:white;border:1px solid rgba(13,57,58,.08);
  padding:14px 16px;font-size:13px;line-height:1.7;color:var(--teal);
  min-height:120px;outline:none;width:100%;resize:vertical;
  font-family:'Inter',sans-serif;
  transition:border-color .15s;
}
.output-text:focus{border-color:var(--gold);}

/* Accordion sektioner i mötesvy - minska scroll, mer fokus */
.accordion-section{
  margin-bottom:8px;
  border:1px solid rgba(13,57,58,.06);
  background:rgba(255,255,255,.4);
  transition:background .15s;
}
.accordion-section[open]{background:white;border-color:rgba(13,57,58,.1);}
.accordion-section > summary{padding:10px 14px;}
.accordion-section > summary::-webkit-details-marker{display:none;}
.accordion-section > summary:hover{background:rgba(236,170,86,.05);}
.accordion-section[open] > summary > span:last-child > .accordion-caret{transform:rotate(180deg);}
.accordion-section[open] .accordion-preview{display:none;}
.accordion-section .accordion-preview{transition:opacity .1s;}

/* Offert-modal accordion-sektioner */
.af-section > summary::-webkit-details-marker{display:none;}
.af-section > summary:hover{background:rgba(236,170,86,.05);}
.af-section[open] > summary .af-caret{transform:rotate(180deg);}
.detail-footer{
  padding:16px 24px;border-top:1px solid rgba(13,57,58,.08);
  display:flex;gap:8px;flex-shrink:0;background:var(--cream);
}
.btn-approve{background:var(--teal);color:var(--cream);padding:0 22px;}
.btn-approve:hover{background:var(--teal-lt);}

/* Footer-knappar: ikoner + text */
.detail-footer .btn svg { width: 13px; height: 13px; flex-shrink: 0; }
.detail-footer .btn-approve svg { width: 14px; height: 14px; }
.btn-label { white-space: nowrap; }
.btn-reject{background:transparent;color:var(--red);border:1.5px solid rgba(239,68,68,.2);}
.btn-reject:hover{border-color:var(--red);}

/* INPUT VIEW */
.input-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.input-card{
  background:white;border:1px solid rgba(13,57,58,.08);padding:24px;
}
.input-card h3{
  font-family:'Cormorant',serif;font-size:20px;font-weight:600;
  color:var(--teal);margin-bottom:4px;
}
.input-card h3 em{font-style:italic;color:var(--gold);}
.input-card p{font-size:12px;color:var(--taupe);line-height:1.6;margin-bottom:16px;}
.form-label{font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--taupe);margin-bottom:6px;display:block;}
.form-input{
  width:100%;background:var(--cream);border:none;
  border-bottom:1.5px solid rgba(13,57,58,.15);
  padding:8px 0;font-size:14px;color:var(--teal);outline:none;
  font-family:'Inter',sans-serif;transition:border-color .15s;margin-bottom:14px;
}
.form-input:focus{border-color:var(--gold);}
.form-textarea{
  width:100%;background:var(--teal-xs);border:1px solid rgba(13,57,58,.1);
  padding:12px 14px;font-size:13px;color:var(--teal);outline:none;
  font-family:'Inter',sans-serif;resize:none;height:180px;line-height:1.65;
  transition:border-color .15s;margin-bottom:14px;
}
.form-textarea:focus{border-color:var(--gold);}
.form-select{
  width:100%;background:var(--cream);border:none;
  border-bottom:1.5px solid rgba(13,57,58,.15);
  padding:8px 0;font-size:14px;color:var(--teal);outline:none;
  font-family:'Inter',sans-serif;cursor:pointer;margin-bottom:14px;
  -webkit-appearance:none;
}
.checkbox-group{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px;}
.checkbox-item{
  font-size:10px;font-weight:600;letter-spacing:.5px;
  padding:5px 12px;cursor:pointer;border:1.5px solid rgba(13,57,58,.15);
  color:rgba(13,57,58,.5);transition:all .15s;user-select:none;
}
.checkbox-item.checked{border-color:var(--teal);color:var(--teal);background:var(--teal-xs);}

/* STATS */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:3px;margin-bottom:20px;}
.stat-card{background:white;padding:16px 18px;border:1px solid rgba(13,57,58,.07);}
.stat-n{font-family:'Cormorant',serif;font-size:32px;font-weight:700;color:var(--teal);line-height:1;}
.stat-n em{font-style:italic;color:var(--gold);}
.stat-l{font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--taupe);margin-top:4px;}

/* HISTORY */
.history-table{width:100%;border-collapse:collapse;}
.history-table th{
  font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  color:var(--taupe);padding:8px 14px;text-align:left;
  border-bottom:2px solid rgba(13,57,58,.1);
}
.history-table td{
  padding:12px 14px;font-size:12px;color:var(--teal);
  border-bottom:1px solid rgba(13,57,58,.06);
}
.history-table tr:hover td{background:rgba(13,57,58,.02);}

/* OVERLAY */
.overlay{
  position:fixed;inset:0;background:rgba(13,57,58,.3);
  z-index:99;opacity:0;pointer-events:none;transition:opacity .25s;
}
.overlay.active{opacity:1;pointer-events:all;}

/* STATUS indicator */
.dot{width:7px;height:7px;border-radius:50%;display:inline-block;margin-right:5px;}
.dot-gold{background:var(--gold);}
.dot-green{background:var(--green);}
.dot-red{background:var(--red);}

/* Empty state */
.empty{text-align:center;padding:60px 20px;}
.empty-icon{font-size:36px;margin-bottom:12px;opacity:.3;}
.empty-text{font-size:13px;color:var(--taupe);}

/* Webhook status */
.webhook-status{
  font-size:10px;font-weight:600;color:var(--taupe);
  display:flex;align-items:center;gap:5px;
}
.ws-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.4;}}

/* Toast */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);
  background:var(--teal);color:var(--cream);padding:10px 20px;
  font-size:12px;font-weight:600;letter-spacing:.5px;
  transition:transform .3s ease;z-index:200;
}
.toast.show{transform:translateX(-50%) translateY(0);}

/* MOBILE */
/* Bottom nav + Hamburger + Mobile Header (mobile) */
.bottom-nav { display: none; }
.hamburger-btn { display: none; }
.sidebar-backdrop { display: none; }
.mobile-header { display: none; }
.sidebar-close { display: none; }

@media(max-width: 700px) {
  body { overflow: auto; flex-direction: column; padding-bottom: 64px; }
  
  /* MOBIL HEADER - sticky top med logo + hamburger */
  .mobile-header {
    display: flex;
    position: sticky; top: 0; z-index: 95;
    background: var(--teal); color: var(--cream);
    padding: 12px 16px;
    align-items: center; justify-content: space-between;
    box-shadow: 0 1px 3px rgba(13,57,58,.1);
  }
  .mobile-header-logo {
    display: flex; align-items: center; gap: 10px;
  }
  .mobile-header-logo img {
    height: 24px;
  }
  
  /* HAMBURGER-KNAPP - höger i mobile-header */
  .hamburger-btn {
    display: flex;
    width: 36px; height: 36px;
    background: transparent; color: var(--cream);
    border: none; cursor: pointer;
    align-items: center; justify-content: center;
    -webkit-tap-highlight-color: transparent;
    padding: 0;
  }
  .hamburger-btn svg { width: 22px; height: 22px; }
  
  /* KRYSS-KNAPP i sidebar - mobil */
  .sidebar-close {
    display: flex;
    position: absolute;
    top: calc(14px + env(safe-area-inset-top));
    right: 18px;
    width: 38px; height: 38px;
    background: var(--cream); color: var(--teal);
    border: none; cursor: pointer; border-radius: 50%;
    align-items: center; justify-content: center;
    -webkit-tap-highlight-color: transparent;
    z-index: 10;
    padding: 0;
    box-shadow: 0 2px 6px rgba(0,0,0,.18);
  }
  .sidebar-close:active { background: var(--gold); }
  .sidebar-close svg { width: 18px; height: 18px; stroke-width: 2.5; }
  
  /* BACKDROP när sidebar öppen */
  .sidebar-backdrop {
    display: block;
    position: fixed; inset: 0;
    background: rgba(13,57,58,.4);
    z-index: 199;
    opacity: 0; pointer-events: none;
    transition: opacity .2s ease;
  }
  .sidebar-backdrop.open {
    opacity: 1; pointer-events: auto;
  }
  
  /* SIDEBAR - glidande från vänster på mobil */
  .sidebar {
    position: fixed; top: 0; bottom: 0; left: 0;
    width: 100%; max-width: 100%;
    height: 100vh;
    height: 100dvh;
    flex-direction: column;
    padding: 0;
    z-index: 200;
    transform: translateX(-100%);
    transition: transform .25s ease;
    overflow-y: auto;
    overscroll-behavior: contain;
  }
  .sidebar.open {
    transform: translateX(0);
  }
  .sidebar-logo {
    padding: calc(18px + env(safe-area-inset-top)) 20px 14px;
    border-bottom: 1px solid rgba(243,228,208,.08);
    border-right: none;
    margin-right: 0;
    display: flex; align-items: center; gap: 10px;
  }
  .sidebar-logo img { height: 26px; }
  .sidebar-sub { 
    display: block;
    font-size: 11px; color: rgba(243,228,208,.5);
    letter-spacing: 1px;
  }
  .sidebar-nav { 
    display: flex; flex-direction: column;
    padding: 16px 0; flex: 1;
    overflow-x: visible;
  }
  .nav-section { 
    display: block;
    padding: 12px 20px 8px;
    font-size: 10px; letter-spacing: 1.5px;
    color: rgba(243,228,208,.4);
    text-transform: uppercase;
  }
  .nav-item { 
    padding: 12px 20px; 
    white-space: normal;
    border-left: 3px solid transparent;
    border-bottom: none;
    font-size: 13px;
    display: flex; align-items: center; gap: 10px;
  }
  .nav-item.active { 
    border-left: 3px solid var(--gold); 
    border-bottom: none;
  }
  .nav-item svg { display: block; width: 16px; height: 16px; }
  .sidebar-footer { 
    display: block;
    padding: 16px 20px;
    border-top: 1px solid rgba(243,228,208,.08);
  }
  
  /* Topbar - göm helt på mobil eftersom hamburger ersätter den */
  .topbar { display: none; }
  
  /* Content - vanlig padding eftersom mobile-header är sticky och tar plats redan */
  .content { padding: 16px; }
  
  /* BOTTOM NAV på mobil */
  .bottom-nav {
    display: flex;
    position: fixed; bottom: 0; left: 0; right: 0;
    background: var(--teal); 
    border-top: 1px solid rgba(243,228,208,.1);
    z-index: 100;
    padding: 6px 0 calc(6px + env(safe-area-inset-bottom));
    justify-content: space-around;
    align-items: center;
  }
  .bottom-nav-item {
    flex: 1; display: flex; flex-direction: column;
    align-items: center; gap: 3px;
    padding: 6px 4px;
    color: rgba(243,228,208,.6);
    font-size: 10px; font-weight: 500;
    cursor: pointer;
    position: relative;
    transition: color .15s;
    -webkit-tap-highlight-color: transparent;
  }
  .bottom-nav-item svg { width: 22px; height: 22px; opacity: .8; transition: opacity .15s; }
  .bottom-nav-item.active { color: var(--gold); }
  .bottom-nav-item.active svg { opacity: 1; }
  .bottom-nav-badge {
    position: absolute; top: 2px; right: 25%;
    background: var(--gold); color: var(--teal);
    font-size: 9px; font-weight: 700;
    min-width: 16px; height: 16px;
    border-radius: 8px;
    display: none; align-items: center; justify-content: center;
    padding: 0 4px;
  }
  .bottom-nav-badge.show { display: flex; }
  
  /* Body locked när sidebar öppen */
  body.sidebar-open { overflow: hidden; }
  .main { height: auto; min-height: 0; }
  .topbar { display: none; }
  .content { padding: 16px; }
  .stats-row { grid-template-columns: 1fr 1fr; gap: 2px; }
  .stat-n { font-size: 24px; }
  .detail-panel { width: 100%; top: auto; bottom: 0; height: 85vh; transform: translateY(100%); border-left: none; border-top: 1px solid rgba(13,57,58,.1); }
  .detail-panel.open { transform: translateY(0); }
  .input-grid { grid-template-columns: 1fr; }
  .filter-row { flex-wrap: nowrap; overflow-x: auto; padding-bottom: 4px; }
  .filter-chip { white-space: nowrap; flex-shrink: 0; }
  .pending-card { flex-wrap: wrap; }
  .card-outputs { display: none; }

  /* Kompakt footer på mobil */
  .detail-footer { padding: 10px 14px; gap: 5px; }
  .detail-footer .btn,
  .detail-footer .btn-sm { height: 32px; padding: 0 10px; font-size: 9.5px; letter-spacing: .6px; gap: 4px; }
  .detail-footer .btn-approve { padding: 0 14px; }
  .detail-footer .btn svg { width: 12px; height: 12px; }
  .detail-footer .btn-approve svg { width: 13px; height: 13px; }
}

/* Mycket smala skärmar: dölj texten, visa bara ikoner — perfekt för iPhone SE/mini */
@media(max-width: 440px) {
  .detail-footer .btn-label { display: none; }
  .detail-footer .btn,
  .detail-footer .btn-sm { padding: 0; width: 38px; min-width: 38px; justify-content: center; gap: 0; }
  .detail-footer .btn-approve { width: 48px; min-width: 48px; padding: 0; }
  .detail-footer .btn svg,
  .detail-footer .btn-approve svg { width: 14px; height: 14px; }
}

/* BOARD */
.board-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 16px; flex-wrap: wrap; gap: 12px;
}
.board-header h2 {
  font-family: 'Cormorant', serif; font-size: 26px; font-weight: 600; color: var(--teal);
}
.board-header h2 em { font-style: italic; color: var(--gold); }
.board {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 10px; align-items: start;
}
.board-col { display: flex; flex-direction: column; gap: 3px; }
.board-col-head {
  padding: 10px 14px; display: flex; align-items: center;
  justify-content: space-between; margin-bottom: 4px;
}
.board-col-title {
  font-size: 10px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
}
.board-col-count {
  font-size: 11px; font-weight: 800; padding: 1px 8px; border-radius: 10px;
}
.board-pending { background: rgba(236,170,86,.15); }
.board-pending .board-col-title { color: #9a6c2a; }
.board-pending .board-col-count { background: rgba(236,170,86,.3); color: #9a6c2a; }
.board-meetings { background: rgba(13,57,58,.06); }
.board-meetings .board-col-title { color: var(--teal); }
.board-meetings .board-col-count { background: rgba(13,57,58,.12); color: var(--teal); }
.board-content-col { background: rgba(34,197,94,.08); }
.board-content-col .board-col-title { color: #166534; }
.board-content-col .board-col-count { background: rgba(34,197,94,.2); color: #166534; }
.board-rejected-col { background: rgba(239,68,68,.07); }
.board-rejected-col .board-col-title { color: #991b1b; }
.board-rejected-col .board-col-count { background: rgba(239,68,68,.15); color: #991b1b; }
.board-list { display: flex; flex-direction: column; gap: 3px; min-height: 60px; }
.board-card {
  background: white; border: 1px solid rgba(13,57,58,.07);
  padding: 12px 14px; cursor: pointer;
  transition: border-color .15s, box-shadow .15s;
  position: relative; overflow: hidden;
}
.board-card::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: transparent; transition: background .15s;
}
.board-card:hover { border-color: rgba(13,57,58,.2); box-shadow: 0 2px 8px rgba(13,57,58,.06); }
.board-card:hover::before { background: var(--gold); }
.board-card-title { font-size: 12px; font-weight: 600; color: var(--teal); margin-bottom: 3px; }
.board-card-meta { font-size: 10px; color: var(--taupe); margin-bottom: 6px; }
.board-chip {
  font-size: 9px; font-weight: 600; padding: 2px 6px;
  background: var(--teal-xs); color: rgba(13,57,58,.5); margin-right: 3px;
  display: inline-block;
}
.board-empty {
  text-align: center; padding: 24px 12px;
  font-size: 11px; color: rgba(13,57,58,.25);
  border: 1.5px dashed rgba(13,57,58,.1);
}
.board-btn-reopen {
  font-size: 9px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  padding: 3px 8px; border: none; cursor: pointer; margin-top: 8px;
  background: rgba(13,57,58,.08); color: var(--teal); transition: all .15s;
}
.board-btn-reopen:hover { background: var(--teal); color: var(--cream); }
@media(max-width: 900px) { .board { grid-template-columns: 1fr 1fr; } }
@media(max-width: 700px) {
  /* På mobil: horizontal scroll-snap mellan kolumner */
  .board {
    display: flex !important;
    grid-template-columns: none !important;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    gap: 12px;
    margin: 0 -16px;
    padding: 0 16px 8px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .board::-webkit-scrollbar { display: none; }
  .board-col {
    flex: 0 0 88vw;
    max-width: 340px;
    scroll-snap-align: center;
  }
  .board-header { flex-direction: column; align-items: flex-start; }

  /* Indicator-dots ovanför kanban-board */
  .board-col-indicator {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    margin: 12px 0 16px;
    padding: 0 16px;
  }
  .board-col-indicator-dot {
    width: 8px; height: 8px;
    background: rgba(13,57,58,.18);
    border: none;
    border-radius: 50%;
    padding: 0;
    cursor: pointer;
    transition: all .2s ease;
    flex-shrink: 0;
  }
  .board-col-indicator-dot:hover { background: rgba(13,57,58,.35); }
  .board-col-indicator-dot.active {
    background: var(--gold);
    width: 24px;
    border-radius: 4px;
  }
  .board-col-indicator-label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--taupe);
    margin: 0 6px;
    min-width: 100px;
    text-align: center;
  }
  /* Större tap-targets på mobile-kort */
  .board-card { min-height: 60px; }
  .board-list { min-height: 200px; }
}
@media(min-width: 701px) {
  /* Dölj indicator-dots på desktop */
  .board-col-indicator { display: none !important; }
}

.schedule-btn {
  font-family: 'Inter', sans-serif; font-size: 10px; font-weight: 600;
  letter-spacing: .3px; padding: 5px 8px;
  border: 1.5px solid rgba(13,57,58,.15); background: transparent;
  color: rgba(13,57,58,.5); cursor: pointer; transition: all .15s;
  white-space: nowrap; flex-shrink: 0;
}
.schedule-btn:hover { border-color: var(--teal); color: var(--teal); }
.schedule-btn.active { border-color: var(--teal); color: var(--teal); background: rgba(13,57,58,.06); }

/* Schemalägg-rad: horisontellt scrollbar på mobil istället för wrap */
.schedule-row {
  display: flex; gap: 6px; flex-wrap: nowrap;
  overflow-x: auto; -webkit-overflow-scrolling: touch;
  padding-bottom: 4px; scrollbar-width: thin;
}
.schedule-row::-webkit-scrollbar { height: 4px; }
.schedule-row::-webkit-scrollbar-thumb { background: rgba(13,57,58,.15); border-radius: 2px; }
@media (max-width: 600px) {
  .schedule-btn { font-size: 9.5px; padding: 5px 7px; letter-spacing: .2px; }
}

/* Top-section accordion på detail-panelen */
details.panel-section {
  background: rgba(236,170,86,.06);
  border-bottom: 1px solid rgba(13,57,58,.08);
  flex-shrink: 0;
}
details.panel-section[open] { background: linear-gradient(to right, rgba(236,170,86,.08), rgba(236,170,86,.03)); }
details.panel-section > summary {
  cursor: pointer; padding: 12px 24px; list-style: none;
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--taupe); user-select: none;
}
details.panel-section > summary::-webkit-details-marker,
details.panel-section > summary::marker { display: none; content: ''; }
details.panel-section > summary:hover { color: var(--teal); }
details.panel-section > summary .panel-caret { transition: transform .15s; flex-shrink: 0; }
details.panel-section[open] > summary .panel-caret { transform: rotate(180deg); }
details.panel-section > .panel-content { padding: 4px 24px 14px 24px; }

/* På mobil: cap:a panel-content max-height när öppen så detail-body får mer plats */
@media (max-width: 768px) {
  details.panel-section > .panel-content {
    max-height: 35vh; overflow-y: auto;
  }
  details.panel-section > summary { padding: 11px 18px; }
  details.panel-section > .panel-content { padding: 4px 18px 12px 18px; }
}

/* AUTO-SYNC INDICATOR */
.sync-status {
  font-size: 10px; font-weight: 600; color: var(--taupe);
  display: flex; align-items: center; gap: 6px;
  padding: 4px 10px; background: rgba(34,197,94,.06);
  border: 1px solid rgba(34,197,94,.15);
}
.sync-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--green); animation: pulse 2s infinite; flex-shrink: 0; }
.sync-status strong { color: var(--teal); font-weight: 700; }

/* PROPOSAL PREVIEW & BUILDER */
.proposal-card {
  background: white; border: 1px solid rgba(13,57,58,.1);
  margin-bottom: 8px; overflow: hidden;
}
.proposal-cover {
  background: var(--teal); color: var(--cream);
  padding: 18px 20px 16px; position: relative;
  border-left: 3px solid var(--gold);
}
.proposal-cover-label {
  font-size: 8px; font-weight: 800; letter-spacing: 2.5px;
  color: var(--gold); margin-bottom: 6px;
}
.proposal-cover-title {
  font-family: 'Cormorant', serif; font-size: 22px; font-weight: 600;
  line-height: 1.15; margin-bottom: 4px;
}
.proposal-cover-tagline {
  font-size: 11px; color: rgba(243,228,208,.7); margin-bottom: 10px;
}
.proposal-cover-divider { width: 32px; height: 2px; background: var(--gold); margin: 8px 0; }
.proposal-cover-meta {
  font-size: 10px; color: rgba(243,228,208,.5);
  display: flex; gap: 8px; align-items: center;
}
.proposal-slide-count {
  position: absolute; top: 14px; right: 16px;
  font-size: 9px; font-weight: 700; letter-spacing: 1.5px;
  color: rgba(243,228,208,.5);
}
.proposal-fields { padding: 14px 18px; background: rgba(13,57,58,.02); }
.proposal-field { margin-bottom: 12px; }
.proposal-field:last-child { margin-bottom: 0; }
.proposal-field-label {
  font-size: 9px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--taupe); margin-bottom: 4px; display: block;
}
.proposal-field-input, .proposal-field-textarea {
  width: 100%; background: white; border: 1px solid rgba(13,57,58,.1);
  padding: 8px 10px; font-size: 12px; color: var(--teal);
  font-family: 'Inter', sans-serif; outline: none;
  transition: border-color .15s; resize: vertical;
}
.proposal-field-textarea { min-height: 60px; line-height: 1.55; }
.proposal-field-input:focus, .proposal-field-textarea:focus { border-color: var(--gold); }
.proposal-row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.proposal-steps { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
.proposal-step {
  background: white; border: 1px solid rgba(13,57,58,.08);
  padding: 8px 10px; position: relative;
  border-top: 2px solid var(--gold);
}
.proposal-step-num {
  font-family: 'Cormorant', serif; font-size: 14px; font-weight: 700;
  color: var(--gold); margin-bottom: 2px;
}
.proposal-step input, .proposal-step textarea {
  width: 100%; border: none; outline: none; font-family: 'Inter', sans-serif;
  background: transparent; padding: 2px 0; resize: none;
}
.proposal-step input { font-size: 11px; font-weight: 700; color: var(--teal); }
.proposal-step textarea { font-size: 10px; color: var(--taupe); line-height: 1.4; min-height: 32px; }
.proposal-investment-list {
  background: white; border: 1px solid rgba(13,57,58,.08);
  padding: 8px 10px;
}
.proposal-invest-row {
  display: flex; gap: 6px; align-items: center; margin-bottom: 4px;
}
.proposal-invest-row:last-child { margin-bottom: 0; }
.proposal-invest-row input {
  flex: 1; border: none; border-bottom: 1px solid rgba(13,57,58,.08);
  padding: 4px 0; font-family: 'Inter', sans-serif; font-size: 11px;
  color: var(--teal); outline: none; background: transparent;
}
.proposal-invest-row input:focus { border-bottom-color: var(--gold); }
.proposal-invest-remove {
  width: 18px; height: 18px; border: none; background: transparent;
  color: rgba(13,57,58,.3); cursor: pointer; font-size: 14px;
  display: flex; align-items: center; justify-content: center;
}
.proposal-invest-remove:hover { color: var(--red); }
.proposal-invest-add {
  margin-top: 4px; background: transparent; border: 1px dashed rgba(13,57,58,.2);
  padding: 4px 8px; font-size: 10px; font-weight: 600; color: var(--taupe);
  cursor: pointer; width: 100%; transition: all .15s;
}
.proposal-invest-add:hover { border-color: var(--gold); color: var(--teal); }
.proposal-download {
  display: flex; gap: 8px; padding: 12px 18px;
  background: var(--teal); color: var(--cream);
  font-family: 'Inter', sans-serif; font-size: 11px; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase;
  cursor: pointer; border: none; width: 100%; align-items: center; justify-content: center;
  transition: background .15s;
}
.proposal-download:hover { background: var(--teal-lt); }
.proposal-download svg { width: 14px; height: 14px; }
.proposal-note {
  font-size: 10px; color: var(--taupe); padding: 8px 18px 0;
  background: rgba(13,57,58,.02); border-top: 1px solid rgba(13,57,58,.05);
  font-style: italic;
}
.proposal-note strong { color: var(--teal); font-style: normal; }

/* REFRESH-KNAPP I TOPBAR */
.refresh-btn {
  width: 32px; height: 32px;
  background: transparent;
  border: 1.5px solid rgba(13,57,58,.15);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--teal);
  transition: all .15s;
  flex-shrink: 0;
  padding: 0;
}
.refresh-btn:hover {
  border-color: var(--teal);
  background: var(--teal-xs);
}
.refresh-btn svg { width: 14px; height: 14px; transition: transform .5s ease; }
.refresh-btn.spinning svg { animation: spin .8s linear infinite; }
@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.last-updated {
  font-size: 10px; color: var(--taupe);
  margin-right: 8px;
  font-family: 'Inter', sans-serif;
}
@media (max-width: 700px) {
  .last-updated { display: none; }
}

/* DRAG-AND-DROP KANBAN */
.board-card.dragging {
  opacity: 0.4;
  cursor: grabbing !important;
  transform: scale(0.97);
}
.board-list.drop-target {
  background: rgba(236,170,86,.08);
  outline: 2px dashed var(--gold);
  outline-offset: -4px;
  min-height: 80px;
}
.board-list {
  min-height: 60px;
  transition: background .15s, outline .15s;
  padding-bottom: 8px;
}
@media (max-width: 700px) {
  /* På touch-enheter visa inte grab-cursor (drag är inaktiv) */
  .board-card[draggable="true"] { cursor: pointer; }
}

/* ─── AI SALES FORECAST (v4.4 - används på Idag) ────────────────────────── */
.ai-forecast-section {
  background: white;
  border: 1px solid rgba(13,57,58,.08);
  margin-bottom: 24px;
  position: relative;
  overflow: hidden;
}
.ai-forecast-section::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: var(--gold);
}
.ai-forecast-head {
  padding: 16px 20px;
  display: flex; justify-content: space-between; align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.ai-forecast-head-left {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.ai-forecast-head-title {
  font-size: 11px; font-weight: 700; letter-spacing: 2px;
  text-transform: uppercase; color: var(--teal);
}
.ai-forecast-head-status {
  font-size: 10px; color: var(--taupe); font-style: italic;
}
.ai-forecast-body { padding: 0 20px 20px; }

.forecast-cards {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 12px; margin-bottom: 18px;
}
.forecast-card {
  background: rgba(13,57,58,.03);
  padding: 14px 16px; border-left: 2px solid var(--gold);
}
.forecast-card-l {
  font-size: 9px; font-weight: 700; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--taupe);
  margin-bottom: 6px;
}
.forecast-card-v {
  font-family: 'Cormorant', serif; font-size: 24px;
  font-weight: 600; color: var(--teal); line-height: 1.1;
}
.forecast-card-sub { font-size: 11px; color: var(--taupe); margin-top: 4px; }

.forecast-insight {
  background: rgba(236,170,86,.06);
  border-left: 3px solid var(--gold);
  padding: 12px 16px; margin-bottom: 16px;
  font-size: 13px; color: var(--teal);
  line-height: 1.6; font-style: italic;
}
.forecast-block { margin-bottom: 16px; }
.forecast-block:last-child { margin-bottom: 0; }
.forecast-block-title {
  font-size: 9px; font-weight: 700; letter-spacing: 2px;
  text-transform: uppercase; color: var(--taupe);
  margin-bottom: 8px;
}
.forecast-list-item {
  background: white; border: 1px solid rgba(13,57,58,.07);
  padding: 10px 14px; margin-bottom: 4px;
  display: flex; gap: 10px; align-items: flex-start;
}
.forecast-list-item.risk { border-left: 3px solid var(--red); }
.forecast-list-item.highlight { border-left: 3px solid var(--green); }
.forecast-list-title { font-size: 12px; font-weight: 600; color: var(--teal); }
.forecast-list-reason { font-size: 11px; color: var(--taupe); margin-top: 2px; line-height: 1.5; }
.forecast-loading {
  text-align: center; padding: 24px;
  color: var(--taupe); font-style: italic; font-size: 12px;
}

.forecast-refresh-btn {
  background: var(--gold);
  color: var(--teal);
  border: none;
  padding: 6px 12px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: inherit;
  transition: background .15s;
}
.forecast-refresh-btn:hover { background: #d99a48; }
.forecast-refresh-btn:disabled { opacity: .5; cursor: not-allowed; }

.forecast-collapse-btn {
  background: transparent; border: 1px solid rgba(13,57,58,.15);
  color: var(--taupe); padding: 5px 8px; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  transition: color .15s, border-color .15s, background .15s;
}
.forecast-collapse-btn:hover {
  color: var(--teal); border-color: var(--gold); background: rgba(212,175,55,.08);
}

@media (max-width: 800px) {
  .forecast-cards { grid-template-columns: 1fr; }
  .ai-forecast-head { flex-direction: column; align-items: flex-start; }
}

/* ─── CALENDAR / MEETINGS PANEL (v4.5) ───────────────────────────────── */
.meetings-panel {
  background: white;
  border: 1px solid rgba(13,57,58,.08);
  padding: 16px 18px;
  margin-top: 16px;
}
.meetings-panel-title {
  font-size: 10px; font-weight: 700; letter-spacing: 2px;
  text-transform: uppercase; color: var(--taupe);
  margin-bottom: 10px;
}
.meetings-loading, .meetings-empty {
  text-align: left;
  padding: 8px 0;
  font-size: 12px;
  color: var(--taupe);
  display: flex; justify-content: space-between; align-items: center; gap: 12px;
  flex-wrap: wrap;
}
.meetings-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 12px;
  flex-wrap: wrap;
  gap: 10px;
}
.meetings-count {
  font-size: 11px;
  color: var(--taupe);
}
.btn-book-meeting {
  background: var(--teal);
  color: #fff;
  border: none;
  padding: 6px 12px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.5px;
  cursor: pointer;
  font-family: inherit;
  transition: background .15s;
}
.btn-book-meeting:hover { background: #0a2d2e; }

.meetings-section { margin-bottom: 14px; }
.meetings-section:last-child { margin-bottom: 0; }
.meetings-section-title {
  font-size: 9px; font-weight: 700; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--gold);
  margin-bottom: 6px;
}
.meetings-toggle {
  display: block; width: 100%;
  background: transparent; border: 1px dashed rgba(13,57,58,.18);
  color: var(--teal); font-family: inherit; font-size: 12px;
  padding: 8px 12px; margin-top: 6px; cursor: pointer;
  transition: background .15s, border-color .15s;
}
.meetings-toggle:hover { background: rgba(13,57,58,.04); border-color: var(--gold); }

/* ─── ATTACHMENTS (v5.5) ─────────────────────────────── */
.attachments-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: 10px;
}
.attachments-empty {
  font-size: 12px; color: var(--taupe); font-style: italic;
  padding: 14px 12px; background: rgba(13,57,58,.03);
  border: 1px dashed rgba(13,57,58,.15);
}
.attachment-card {
  position: relative;
  background: rgba(13,57,58,.04);
  border: 1px solid rgba(13,57,58,.1);
  padding: 8px;
  font-size: 11px;
  display: flex; flex-direction: column;
  min-height: 130px;
  transition: border-color .15s;
}
.attachment-card:hover { border-color: var(--gold); }
.attachment-link {
  text-decoration: none; color: var(--teal);
  display: flex; flex-direction: column;
  align-items: center; gap: 4px;
  flex: 1;
}
.attachment-thumb {
  width: 100%; height: 80px;
  object-fit: cover;
  background: white;
}
.attachment-icon {
  font-size: 36px;
  width: 100%; height: 80px;
  display: flex; align-items: center; justify-content: center;
  background: var(--cream);
}
.attachment-filename {
  font-size: 11px; line-height: 1.3;
  text-align: center;
  word-break: break-word;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-top: 4px;
}
.attachment-size { color: var(--taupe); font-size: 10px; margin-top: 2px; }
.attachment-delete {
  position: absolute; top: 4px; right: 4px;
  background: rgba(255,255,255,.95); border: 1px solid rgba(239,68,68,.35);
  color: var(--red);
  width: 22px; height: 22px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 14px; line-height: 1;
  display: none;
  align-items: center; justify-content: center;
  padding: 0;
}
.attachment-card:hover .attachment-delete { display: flex; }
.attachment-delete:hover { background: var(--red); color: white; }

.attachments-upload-zone {
  border: 2px dashed rgba(13,57,58,.25);
  background: rgba(13,57,58,.02);
  padding: 14px 10px;
  text-align: center;
  cursor: pointer;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  min-height: 130px;
  transition: background .15s, border-color .15s;
}
.attachments-upload-zone:hover,
.attachments-upload-zone.drag-over {
  background: rgba(212,175,55,.1);
  border-color: var(--gold);
}
.attachments-upload-icon {
  font-size: 28px; color: var(--taupe);
  margin-bottom: 6px; line-height: 1;
}
.attachments-upload-text {
  font-size: 12px; color: var(--teal);
  font-weight: 500;
}
.attachments-upload-hint {
  font-size: 10px; color: var(--taupe);
  margin-top: 2px;
}
.attachments-uploading {
  font-size: 12px; color: var(--gold);
  font-style: italic;
}

/* Click-to-call / mailto - action-länkar bredvid form-fält */
.field-action {
  text-decoration: none; color: var(--gold);
  font-size: 14px; padding: 2px 6px;
  border: 1px solid rgba(212,175,55,.35);
  display: inline-flex; align-items: center;
  transition: background .15s, color .15s, border-color .15s;
}
.field-action:hover { background: var(--gold); color: white; border-color: var(--gold); }
.contact-mailto {
  color: inherit; text-decoration: none;
  border-bottom: 1px dotted rgba(13,57,58,.3);
  transition: color .15s, border-color .15s;
}
.contact-mailto:hover { color: var(--gold); border-color: var(--gold); }

/* KPI-STRIP (v5.6) */
.kpi-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin: 20px 0 24px;
}
.kpi-card {
  background: var(--cream); border: 1px solid rgba(13,57,58,.1);
  padding: 14px 16px;
}
.kpi-card.kpi-warning { border-color: rgba(212,175,55,.45); background: rgba(212,175,55,.05); }
.kpi-label {
  font-size: 9px; font-weight: 700; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--taupe);
  margin-bottom: 6px;
}
.kpi-value {
  font-family: 'Cormorant', serif;
  font-size: 28px; font-weight: 600; color: var(--teal);
  line-height: 1.1;
}
.kpi-card.kpi-warning .kpi-value { color: var(--gold); }
.kpi-sub {
  font-size: 11px; color: var(--taupe);
  margin-top: 4px;
}
@media (max-width: 800px) {
  .kpi-strip { grid-template-columns: repeat(2, 1fr); }
  .kpi-value { font-size: 22px; }
}

/* STALE-DEAL-BANNER */
.stale-banner {
  display: flex; gap: 14px; align-items: flex-start;
  background: rgba(239,68,68,.06);
  border: 1px solid rgba(239,68,68,.3);
  padding: 14px 18px;
  margin-bottom: 20px;
}
.stale-banner-icon { font-size: 22px; line-height: 1; color: var(--red); }
.stale-banner-body { flex: 1; }
.stale-banner-title {
  font-family: 'Cormorant', serif;
  font-size: 17px; color: var(--teal); margin-bottom: 8px;
}
.stale-banner-list {
  display: flex; flex-wrap: wrap; gap: 8px;
}
.stale-deal-link {
  display: inline-flex; flex-direction: column;
  background: white; border: 1px solid rgba(13,57,58,.1);
  padding: 6px 10px;
  text-decoration: none;
  transition: border-color .15s;
  min-width: 0;
}
.stale-deal-link:hover { border-color: var(--gold); }
.stale-deal-title { font-size: 12px; color: var(--teal); font-weight: 500; }
.stale-deal-meta { font-size: 10px; color: var(--taupe); margin-top: 2px; }

/* GLOBALT SÖK (v5.6) - Cmd+K */
.gsearch-backdrop {
  display: none; position: fixed; inset: 0;
  background: rgba(13,57,58,.55);
  z-index: 2000;
  align-items: flex-start; justify-content: center;
  padding-top: 12vh;
}
.gsearch-backdrop.show { display: flex; }
.gsearch-card {
  background: var(--cream);
  width: 100%; max-width: 580px;
  border: 1px solid rgba(13,57,58,.15);
  box-shadow: 0 12px 36px rgba(13,57,58,.25);
}
.gsearch-input {
  width: 100%; box-sizing: border-box;
  border: none; outline: none;
  background: white;
  padding: 18px 22px;
  font-family: inherit; font-size: 15px;
  color: var(--teal);
  border-bottom: 1px solid rgba(13,57,58,.08);
}
.gsearch-hint {
  padding: 8px 22px; font-size: 11px; color: var(--taupe);
  background: rgba(13,57,58,.02);
  border-bottom: 1px solid rgba(13,57,58,.06);
}
.gsearch-results { max-height: 50vh; overflow-y: auto; }
.gsearch-result {
  display: grid; grid-template-columns: 32px 1fr auto;
  align-items: center; gap: 12px;
  padding: 10px 22px;
  text-decoration: none; color: var(--teal);
  border-bottom: 1px solid rgba(13,57,58,.05);
  transition: background .1s;
}
.gsearch-result.active, .gsearch-result:hover { background: rgba(212,175,55,.1); }
.gsearch-icon { font-size: 18px; line-height: 1; }
.gsearch-text { min-width: 0; }
.gsearch-title { font-size: 13px; font-weight: 500; color: var(--teal); }
.gsearch-sub { font-size: 11px; color: var(--taupe); margin-top: 2px; }
.gsearch-type {
  font-size: 9px; letter-spacing: 1px; text-transform: uppercase;
  color: var(--gold); background: rgba(212,175,55,.1);
  padding: 3px 7px;
}
.gsearch-empty { padding: 22px; text-align: center; color: var(--taupe); font-size: 13px; font-style: italic; }
.meeting-row {
  display: grid;
  grid-template-columns: 130px 1fr auto;
  gap: 10px;
  padding: 8px 10px;
  border-left: 2px solid rgba(13,57,58,.1);
  background: rgba(13,57,58,.02);
  margin-bottom: 4px;
  align-items: center;
}
.meeting-row.upcoming { border-left-color: var(--gold); }
.meeting-row.past { opacity: 0.75; }
.meeting-time {
  font-size: 11px;
  color: var(--teal);
  font-weight: 600;
}
.meeting-title {
  font-size: 12px;
  color: var(--teal);
  font-weight: 500;
  line-height: 1.3;
}
.meeting-loc {
  font-size: 10px;
  color: var(--taupe);
  margin-top: 2px;
}
.meeting-actions {
  display: flex; gap: 6px; align-items: center;
}
.meeting-link {
  font-size: 11px;
  font-weight: 600;
  color: var(--teal);
  text-decoration: none;
  padding: 3px 8px;
  background: rgba(236,170,86,.15);
  transition: background .15s;
}
.meeting-link:hover { background: rgba(236,170,86,.3); }

@media (max-width: 640px) {
  .meeting-row { grid-template-columns: 1fr; gap: 4px; }
  .meeting-actions { justify-content: flex-start; }
}

/* ─── BOOKING MODAL ─── */
#bookMeetingModal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(13,57,58,.6);
  z-index: 9999;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.bm-card {
  background: #fff;
  max-width: 500px;
  width: 100%;
  padding: 28px 28px 24px;
  box-shadow: 0 20px 60px rgba(0,0,0,.3);
  max-height: 90vh;
  overflow-y: auto;
}
.bm-title {
  font-family: 'Cormorant', serif;
  font-size: 24px;
  font-weight: 600;
  color: var(--teal);
  margin-bottom: 4px;
}
.bm-title em { font-style: italic; color: var(--gold); }
.bm-sub {
  font-size: 12px;
  color: var(--taupe);
  margin-bottom: 18px;
}
.bm-row { margin-bottom: 14px; }
.bm-row label {
  display: block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--taupe);
  margin-bottom: 4px;
}
.bm-row input[type="text"],
.bm-row input[type="datetime-local"],
.bm-row select,
.bm-row textarea {
  width: 100%;
  padding: 9px 11px;
  font-size: 13px;
  font-family: inherit;
  border: 1px solid rgba(13,57,58,.15);
  background: #fff;
  color: var(--teal);
  outline: none;
}
.bm-row textarea { min-height: 60px; resize: vertical; }
.bm-row input:focus, .bm-row select:focus, .bm-row textarea:focus { border-color: var(--gold); }
.bm-mode-row {
  display: flex; gap: 16px;
}
.bm-mode-row label {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13px; color: var(--teal); cursor: pointer;
  letter-spacing: 0; text-transform: none; font-weight: 500;
  margin-bottom: 0;
}
.bm-actions {
  display: flex; gap: 10px; justify-content: flex-end;
  margin-top: 18px;
}
.bm-actions button {
  padding: 10px 18px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  font-family: inherit;
  border: none;
  transition: background .15s;
}
.bm-cancel-btn {
  background: transparent;
  color: var(--teal);
  border: 1px solid rgba(13,57,58,.2) !important;
}
.bm-cancel-btn:hover { background: var(--teal-xs); }
.bm-submit-btn {
  background: var(--teal);
  color: #fff;
}
.bm-submit-btn:hover { background: #0a2d2e; }
.bm-submit-btn:disabled { background: var(--taupe); cursor: not-allowed; }
