/* =================================================================
   MLE Platform — client command center
   Same design system as the Coastal site (Gulf Coast Command Center)
   ================================================================= */
:root{
  --sand:#FBF7EF; --sand-2:#F4ECDD; --shell:#FFFFFF;
  --ink:#0A2A38; --ink-soft:#2C4A57; --ink-mute:#5E7884;
  --teal:#0E7A8C; --teal-bright:#19B5C9; --teal-deep:#073C47; --teal-ink:#04222A;
  --aqua-mist:#DDEEF0;
  --coral:#FF6B57; --coral-deep:#E8513C; --gold:#F2B441;
  --display:"Fraunces",Georgia,serif; --sans:"Figtree",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,Menlo,monospace;
  --radius:16px; --radius-sm:11px;
  --ease:cubic-bezier(.22,1,.36,1);
  --line:rgba(221,238,240,.12); --line-soft:rgba(221,238,240,.07);
  --panel:#062B34; --panel-2:#07333E;
  --txt:#E9F4F5; --txt-soft:#A8C6CC; --txt-mute:#6E939B;
  --ok:#3ECF8E; --warn:#F2B441;
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--sans);font-size:1rem;line-height:1.6;
  -webkit-font-smoothing:antialiased;color:var(--txt);background:var(--teal-ink)}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
input{font-family:inherit}
h1,h2,h3{font-family:var(--display);font-weight:560;line-height:1.08;letter-spacing:-.015em;margin:0}
.mono{font-family:var(--mono)}
::selection{background:var(--teal-bright);color:#fff}
.reduce-motion *,.reduce-motion *::before,.reduce-motion *::after{
  animation:none!important;transition:none!important}

/* ---------- shared bits ---------- */
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--display);
  font-size:1.14rem;font-weight:560;letter-spacing:-.01em}
.brand em{font-style:normal;color:var(--teal-bright)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.85rem 1.5rem;border-radius:999px;font-weight:600;font-size:.98rem;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s}
.btn-coral{background:var(--coral);color:#fff;box-shadow:0 14px 30px -12px rgba(255,107,87,.55)}
.btn-coral:hover{background:var(--coral-deep);transform:translateY(-2px)}
.btn-coral:disabled{opacity:.45;cursor:not-allowed;transform:none}
.btn-ghost{background:transparent;border:1px solid rgba(10,42,56,.25);color:var(--ink)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal)}
.btn-demo{background:var(--aqua-mist);color:var(--teal-deep);width:100%}
.btn-demo:hover{background:#cfe7ea;transform:translateY(-2px)}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.dot-live{background:var(--ok);box-shadow:0 0 0 0 rgba(62,207,142,.5);animation:pulse 2.2s infinite}
@keyframes pulse{70%{box-shadow:0 0 0 9px rgba(62,207,142,0)}100%{box-shadow:0 0 0 0 rgba(62,207,142,0)}}
.toast{position:fixed;left:50%;bottom:1.6rem;transform:translate(-50%,140%);
  background:var(--shell);color:var(--ink);font-weight:600;font-size:.92rem;
  padding:.8rem 1.3rem;border-radius:999px;box-shadow:0 18px 44px rgba(0,0,0,.35);
  transition:transform .45s var(--ease);z-index:60;max-width:90vw}
.toast.show{transform:translate(-50%,0)}

/* =================================================================
   LOGIN
   ================================================================= */
.login-page{background:var(--sand);color:var(--ink)}
.login-split{display:grid;grid-template-columns:1.1fr 1fr;min-height:100vh}
.login-visual{position:relative;overflow:hidden;background:var(--teal-deep)}
.login-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.85}
.login-visual::after{content:"";position:absolute;inset:0;
  background:linear-gradient(160deg,rgba(4,34,42,.25),rgba(4,34,42,.88) 82%)}
.login-visual-inner{position:relative;z-index:2;display:flex;flex-direction:column;
  justify-content:space-between;height:100%;padding:clamp(1.6rem,3.5vw,3.2rem);color:#fff}
.login-visual .brand{color:#fff}
.eyebrow{font-family:var(--mono);font-size:.74rem;letter-spacing:.14em;color:var(--teal-bright);margin:0 0 1rem}
.login-pitch h1{color:#fff;font-size:clamp(2.4rem,4.2vw,3.9rem);margin-bottom:1.1rem}
.login-sub{color:rgba(233,244,245,.82);max-width:38ch;font-size:1.08rem;margin:0}
.login-foot{font-size:.72rem;letter-spacing:.12em;color:rgba(233,244,245,.5);margin:0}
.login-panel{display:grid;place-items:center;padding:clamp(1.5rem,4vw,3rem)}
.login-card{width:min(420px,100%)}
.login-card h2{font-size:2rem;margin-bottom:.4rem}
.login-hint{color:var(--ink-mute);margin:0 0 1.6rem;font-size:.95rem}
#login-form{display:flex;flex-direction:column;gap:.45rem}
#login-form label{font-size:.8rem;font-weight:600;letter-spacing:.04em;color:var(--ink-soft);margin-top:.6rem}
#login-form input{padding:.85rem 1rem;border:1px solid rgba(10,42,56,.18);border-radius:var(--radius-sm);
  background:#fff;font-size:1rem;color:var(--ink);transition:border-color .2s,box-shadow .2s}
#login-form input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(14,122,140,.14)}
#btn-signin{margin-top:1.1rem}
#login-form .btn-ghost{margin-top:.5rem;font-size:.9rem;padding:.7rem 1.2rem}
.form-msg{min-height:1.3em;font-size:.88rem;color:var(--coral-deep);margin:.5rem 0 0}
.form-msg.ok{color:#0E8C5F}
.login-divider{display:flex;align-items:center;gap:.9rem;color:var(--ink-mute);
  font-size:.8rem;margin:1.4rem 0}
.login-divider::before,.login-divider::after{content:"";flex:1;height:1px;background:rgba(10,42,56,.14)}
.login-legal{font-size:.83rem;color:var(--ink-mute);margin-top:1.4rem;line-height:1.55}
.login-legal a{color:var(--teal);font-weight:600}

/* =================================================================
   APP SHELL
   ================================================================= */
.app-shell{display:grid;grid-template-columns:236px 1fr;min-height:100vh}
.side{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;
  background:var(--teal-deep);border-right:1px solid var(--line-soft);padding:1.3rem 1rem}
.brand-side{color:#fff;padding:.3rem .5rem 1.3rem}
.side-nav{display:flex;flex-direction:column;gap:.25rem;flex:1}
.side-nav button{display:flex;align-items:center;gap:.7rem;padding:.68rem .8rem;
  border-radius:var(--radius-sm);font-size:.94rem;font-weight:500;color:var(--txt-soft);
  transition:background .2s,color .2s;text-align:left}
.side-nav button svg{width:19px;height:19px;flex:none}
.side-nav button:hover{background:var(--panel);color:var(--txt)}
.side-nav button.active{background:var(--panel-2);color:#fff;box-shadow:inset 2px 0 0 var(--teal-bright)}
.nav-pill{margin-left:auto;font-family:var(--mono);font-size:.66rem;background:rgba(242,180,65,.16);
  color:var(--gold);padding:.14rem .45rem;border-radius:6px}
.side-foot{border-top:1px solid var(--line-soft);padding-top:1rem;display:flex;
  flex-direction:column;gap:.7rem}
.side-status{display:flex;align-items:center;gap:.55rem;font-family:var(--mono);
  font-size:.72rem;letter-spacing:.05em;color:var(--ok)}
.btn-signout{font-size:.85rem;color:var(--txt-mute);text-align:left;padding:.2rem .1rem}
.btn-signout:hover{color:var(--coral)}

.main{padding:1.6rem clamp(1.2rem,3vw,2.6rem) 3rem;min-width:0}
.topbar{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:1.4rem}
.top-kicker{font-size:.7rem;letter-spacing:.16em;color:var(--teal-bright);margin:0 0 .3rem}
.topbar h1{font-size:clamp(1.7rem,2.6vw,2.3rem);color:#fff}
.top-org{display:flex;align-items:center;gap:.7rem}
.org-name{font-size:.92rem;color:var(--txt-soft)}
.org-avatar{width:38px;height:38px;border-radius:50%;background:var(--gold);color:var(--teal-ink);
  display:grid;place-items:center;font-weight:700}
.demo-banner{background:rgba(242,180,65,.14);border:1px dashed rgba(242,180,65,.5);
  color:var(--gold);font-family:var(--mono);font-size:.76rem;letter-spacing:.03em;
  padding:.55rem .9rem;border-radius:var(--radius-sm);margin-bottom:1.3rem}
.demo-banner a{text-decoration:underline}

.view{display:none;animation:viewin .5s var(--ease)}
.view.active{display:block}
@keyframes viewin{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.view-intro{color:var(--txt-soft);max-width:62ch;margin:0 0 1.4rem;font-size:.98rem}
.view-intro b{color:#fff}

.panel{background:var(--panel);border:1px solid var(--line-soft);border-radius:var(--radius);
  padding:1.25rem 1.35rem;margin-bottom:1.3rem}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}
.panel-head h2{font-size:1.18rem;color:#fff}
.panel-tag{font-size:.64rem;letter-spacing:.13em;color:var(--txt-mute)}
.panel-link{font-size:.86rem;color:var(--teal-bright);font-weight:600}

/* ---------- overview ---------- */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.3rem}
.kpi{background:var(--panel);border:1px solid var(--line-soft);border-radius:var(--radius);padding:1.05rem 1.15rem}
.kpi-label{font-family:var(--mono);font-size:.64rem;letter-spacing:.12em;color:var(--txt-mute);margin:0 0 .45rem}
.kpi-num{font-family:var(--display);font-size:2.1rem;font-weight:560;color:#fff;margin:0;line-height:1}
.kpi-num i{font-style:normal;font-size:1.1rem;color:var(--teal-bright)}
.kpi-sub{font-family:var(--mono);font-size:.7rem;color:var(--txt-mute);margin:.5rem 0 0}
.kpi-sub.up{color:var(--ok)}
.ov-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:1.3rem}
.feed{display:flex;flex-direction:column;gap:.6rem;min-height:280px}
.feed-item{display:flex;align-items:center;gap:.85rem;background:var(--panel-2);
  border:1px solid var(--line-soft);border-radius:var(--radius-sm);padding:.7rem .9rem;
  animation:viewin .45s var(--ease)}
.fi-ico{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;flex:none}
.fi-ico svg{width:17px;height:17px}
.fi-txt{min-width:0;flex:1}
.fi-txt b{display:block;font-size:.9rem;color:var(--txt);font-weight:600;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fi-txt span{font-size:.76rem;color:var(--txt-mute)}
.fi-time{font-family:var(--mono);font-size:.7rem;color:var(--txt-mute);flex:none}
.stack{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem}
.chip{display:flex;flex-direction:column;align-items:center;gap:.4rem;background:var(--panel-2);
  border:1px solid var(--line-soft);border-radius:var(--radius-sm);padding:.85rem .4rem;
  font-family:var(--mono);font-size:.66rem;color:var(--txt-mute);position:relative;
  transition:border-color .3s,color .3s}
.chip svg{width:20px;height:20px;color:var(--teal-bright)}
.chip.on{border-color:rgba(62,207,142,.4);color:var(--txt-soft)}
.chip.on::after{content:"";position:absolute;top:7px;right:7px;width:6px;height:6px;
  border-radius:50%;background:var(--ok)}
.chip.fire{border-color:var(--teal-bright);color:#fff}
.stack-foot{font-size:.7rem;letter-spacing:.06em;color:var(--txt-mute);margin:.9rem 0 0}
.stack-foot b{color:var(--ok)}

/* ---------- connections ---------- */
.vault-group{margin-bottom:1.5rem}
.vault-group>h2{font-size:1.05rem;color:#fff;margin-bottom:.25rem}
.vault-group>p{font-size:.85rem;color:var(--txt-mute);margin:0 0 .8rem}
.conn{display:flex;align-items:center;gap:1rem;background:var(--panel);
  border:1px solid var(--line-soft);border-radius:var(--radius);padding:.95rem 1.15rem;margin-bottom:.6rem;flex-wrap:wrap}
.conn-ico{width:40px;height:40px;border-radius:10px;background:var(--panel-2);
  display:grid;place-items:center;font-family:var(--mono);font-weight:600;font-size:.8rem;
  color:var(--teal-bright);flex:none}
.conn-txt{flex:1;min-width:200px}
.conn-txt b{display:block;font-size:.95rem;color:var(--txt)}
.conn-txt span{font-size:.79rem;color:var(--txt-mute)}
.conn-state{font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;padding:.3rem .7rem;border-radius:999px}
.conn-state.ok{background:rgba(62,207,142,.13);color:var(--ok)}
.conn-state.need{background:rgba(242,180,65,.13);color:var(--gold)}
.conn-act .btn{padding:.55rem 1.1rem;font-size:.85rem}
.conn-key{display:flex;gap:.5rem;width:100%;margin-top:.4rem}
.conn-key input{flex:1;background:var(--teal-ink);border:1px solid var(--line);
  border-radius:var(--radius-sm);color:var(--txt);font-family:var(--mono);font-size:.8rem;padding:.6rem .8rem}
.conn-key input:focus{outline:none;border-color:var(--teal-bright)}
.conn-key .btn{padding:.55rem 1rem;font-size:.82rem}

/* ---------- automations ---------- */
.auto-head{display:flex;gap:1rem;align-items:flex-start;justify-content:space-between;flex-wrap:wrap}
#auto-search{background:var(--panel);border:1px solid var(--line);border-radius:999px;
  color:var(--txt);padding:.7rem 1.2rem;font-size:.92rem;width:min(340px,100%)}
#auto-search:focus{outline:none;border-color:var(--teal-bright)}
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:.8rem;margin-bottom:1.5rem}
.cat{background:var(--panel);border:1px solid var(--line-soft);border-radius:var(--radius);
  padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.35rem;transition:transform .25s var(--ease),border-color .25s}
.cat:hover{transform:translateY(-3px);border-color:rgba(25,181,201,.4)}
.cat b{font-size:.95rem;color:var(--txt);line-height:1.3}
.cat .mono{font-size:.68rem;color:var(--txt-mute);letter-spacing:.05em}
.cat-add{margin-top:.5rem;align-self:flex-start;font-size:.8rem;font-weight:600;color:var(--teal-bright);
  border:1px solid rgba(25,181,201,.35);padding:.3rem .8rem;border-radius:999px;transition:background .2s,color .2s}
.cat-add:hover{background:var(--teal-bright);color:var(--teal-ink)}
.cat-add.added{background:rgba(62,207,142,.14);border-color:rgba(62,207,142,.4);color:var(--ok)}
.sel-list{margin:0;padding:0;list-style:none}
.sel-list li{display:flex;justify-content:space-between;gap:1rem;font-size:.9rem;color:var(--txt-soft);
  padding:.45rem 0;border-bottom:1px solid var(--line-soft)}
.sel-list button{color:var(--coral);font-size:.8rem}
.sel-empty{font-size:.88rem;color:var(--txt-mute)}
.selected-panel .btn{margin-top:1rem}

/* ---------- studio ---------- */
.studio-grid{display:grid;grid-template-columns:1.25fr 1fr;gap:1.3rem;margin-bottom:1.3rem;align-items:start}
.st-upload-btn{padding:.5rem 1.1rem;font-size:.85rem;cursor:pointer}
.st-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.7rem}
.st-item{margin:0;position:relative;border-radius:var(--radius-sm);overflow:hidden;
  border:2px solid transparent;background:var(--panel-2);transition:border-color .25s}
.st-item.ref{border-color:var(--gold)}
.st-item img,.st-item video{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.st-item figcaption{display:flex;align-items:center;justify-content:space-between;gap:.4rem;
  padding:.4rem .55rem;font-size:.72rem;color:var(--txt-soft)}
.st-item figcaption>span:first-child{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.st-tools{display:flex;gap:.15rem;flex:none}
.st-tools button{padding:.1rem .35rem;border-radius:6px;color:var(--txt-mute);font-size:.85rem}
.st-tools button:hover{color:#fff;background:var(--teal-ink)}
.st-item.ref .st-tools [data-ref]{color:var(--gold)}
#st-voice,#st-brief,#st-prompt{width:100%;background:var(--teal-ink);border:1px solid var(--line);
  border-radius:var(--radius-sm);color:var(--txt);font-size:.9rem;padding:.7rem .85rem;
  margin-bottom:.6rem;font-family:var(--sans);resize:vertical}
#st-voice:focus,#st-brief:focus,#st-prompt:focus{outline:none;border-color:var(--teal-bright)}
#st-prompt{font-family:var(--mono);font-size:.78rem;color:var(--txt-soft)}
.st-kind{display:flex;gap:.5rem;margin-bottom:.7rem}
.st-kind-btn{flex:1;padding:.55rem;border:1px solid var(--line);border-radius:var(--radius-sm);
  font-size:.88rem;color:var(--txt-soft);transition:border-color .2s,color .2s}
.st-kind-btn.on{border-color:var(--teal-bright);color:#fff;background:var(--panel-2)}
.st-refs{font-size:.66rem;letter-spacing:.05em;color:var(--txt-mute);margin:0 0 .7rem}
#st-draft{width:100%;margin-bottom:.6rem}
#st-request{width:100%}
.st-jobs{display:flex;flex-direction:column;gap:.55rem}
@media (max-width:1080px){.studio-grid{grid-template-columns:1fr}}

/* ---------- social ---------- */
.soc-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem;margin-bottom:1.3rem}
.soc-channels{display:flex;flex-wrap:wrap;gap:.6rem}
.soc-ch{display:flex;align-items:center;gap:.55rem;background:var(--panel-2);
  border:1px solid var(--line-soft);border-radius:999px;padding:.45rem .9rem .45rem .5rem;
  transition:border-color .25s,opacity .25s;opacity:.55}
.soc-ch.on{border-color:rgba(62,207,142,.45);opacity:1}
.soc-ch-ico{width:28px;height:28px;border-radius:50%;background:var(--teal-ink);
  display:grid;place-items:center;font-family:var(--mono);font-size:.72rem;color:var(--teal-bright);flex:none}
.soc-ch-name{font-size:.86rem;color:var(--txt);font-weight:600}
.soc-ch-net{font-size:.62rem;color:var(--txt-mute);letter-spacing:.06em}
#soc-text,#soc-img,#soc-topic{width:100%;background:var(--teal-ink);border:1px solid var(--line);
  border-radius:var(--radius-sm);color:var(--txt);font-size:.94rem;padding:.75rem .9rem;
  margin-bottom:.6rem;font-family:var(--sans);resize:vertical}
#soc-text:focus,#soc-img:focus,#soc-topic:focus{outline:none;border-color:var(--teal-bright)}
.soc-when{display:flex;gap:.6rem;margin-bottom:.8rem;flex-wrap:wrap}
#soc-date{flex:1;min-width:190px;background:var(--teal-ink);border:1px solid var(--line);
  border-radius:var(--radius-sm);color:var(--txt);padding:.55rem .8rem;font-family:var(--mono);font-size:.8rem}
#soc-date:focus{outline:none;border-color:var(--teal-bright)}
.btn-ghost-dark{background:transparent;border:1px solid var(--line);color:var(--txt-soft);
  padding:.55rem 1.1rem;font-size:.85rem}
.btn-ghost-dark:hover{border-color:var(--teal-bright);color:#fff}
.soc-actions{display:flex;gap:.6rem;flex-wrap:wrap}
.soc-actions .btn,#soc-gen{padding:.65rem 1.3rem;font-size:.9rem}
#soc-gen{width:100%;margin-bottom:.9rem}
.soc-drafts{display:flex;flex-direction:column;gap:.55rem;margin-bottom:.9rem}
.soc-draft{display:flex;gap:.6rem;align-items:flex-start}
.soc-day{flex:none;width:2.6rem;padding-top:.6rem;font-size:.68rem;color:var(--gold);letter-spacing:.08em}
.soc-draft textarea{flex:1;background:var(--panel-2);border:1px solid var(--line-soft);
  border-radius:var(--radius-sm);color:var(--txt);font-size:.87rem;padding:.55rem .7rem;
  font-family:var(--sans);resize:vertical}
.soc-draft textarea:focus{outline:none;border-color:var(--teal-bright)}
.soc-x{flex:none;color:var(--txt-mute);font-size:1.1rem;padding:.3rem .5rem;border-radius:8px}
.soc-x:hover{color:var(--coral);background:rgba(255,107,87,.1)}
#soc-schedule-all{width:100%}
.soc-queue{display:flex;flex-direction:column;gap:.55rem}
.soc-item{display:flex;align-items:center;gap:.8rem;background:var(--panel-2);
  border:1px solid var(--line-soft);border-radius:var(--radius-sm);padding:.65rem .9rem}
.soc-item-txt{flex:1;min-width:0}
.soc-item-txt b{display:block;font-size:.88rem;color:var(--txt);font-weight:500;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.soc-item-txt .mono{font-size:.68rem;color:var(--txt-mute)}
@media (max-width:1080px){.soc-grid{grid-template-columns:1fr}}

/* ---------- radar ---------- */
.rd-config{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.6rem;margin-bottom:.8rem}
.rd-config input{background:var(--teal-ink);border:1px solid var(--line);border-radius:var(--radius-sm);
  color:var(--txt);font-size:.88rem;padding:.65rem .85rem}
.rd-config input:focus{outline:none;border-color:var(--teal-bright)}
.rd-insights{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.7rem}
.rd-insight{background:var(--panel-2);border:1px solid var(--line-soft);border-left:3px solid var(--gold);
  border-radius:var(--radius-sm);padding:.8rem .95rem}
.rd-insight b{display:block;font-size:.92rem;color:#fff;margin-bottom:.25rem}
.rd-insight span{font-size:.8rem;color:var(--txt-soft)}
.rd-plan{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:.9rem}
.rd-card{background:var(--panel-2);border:1px solid var(--line-soft);border-radius:var(--radius);
  padding:.95rem 1.05rem;display:flex;flex-direction:column;gap:.55rem}
.rd-card.scheduled{border-color:rgba(62,207,142,.35)}
.rd-card-head{display:flex;justify-content:space-between;align-items:center;gap:.6rem}
.rd-fmt{font-size:.74rem;font-weight:700;letter-spacing:.06em;color:var(--teal-bright)}
.rd-time{font-size:.68rem;color:var(--gold)}
.rd-why{font-size:.64rem;letter-spacing:.06em;color:var(--txt-mute);margin:0}
.rd-card textarea{width:100%;background:var(--teal-ink);border:1px solid var(--line);
  border-radius:var(--radius-sm);color:var(--txt);font-size:.87rem;padding:.55rem .7rem;
  font-family:var(--sans);resize:vertical}
.rd-card textarea:focus{outline:none;border-color:var(--teal-bright)}
.rd-script summary{cursor:pointer;font-size:.8rem;color:var(--teal-bright);font-weight:600;margin-bottom:.4rem}
.rd-script textarea{font-size:.8rem;color:var(--txt-soft);margin-bottom:.4rem}
.rd-img{font-size:.68rem;color:var(--txt-mute);margin:0;letter-spacing:.03em}
.rd-actions{display:flex;gap:.5rem;align-items:center;margin-top:auto}
.rd-approve{padding:.5rem 1rem;font-size:.82rem}
@media (max-width:880px){.rd-config{grid-template-columns:1fr}}

/* ---------- reports ---------- */
.scan-form{display:flex;gap:.7rem;flex-wrap:wrap}
.scan-form input{flex:1;min-width:240px;background:var(--teal-ink);border:1px solid var(--line);
  border-radius:999px;color:var(--txt);font-size:.95rem;padding:.8rem 1.2rem}
.scan-form input:focus{outline:none;border-color:var(--teal-bright)}
.report h3{color:#fff;font-size:1.05rem;margin:1.1rem 0 .5rem}
.rec{display:flex;gap:1rem;align-items:flex-start;background:var(--panel-2);border:1px solid var(--line-soft);
  border-radius:var(--radius-sm);padding:.9rem 1rem;margin-bottom:.6rem}
.rec-score{font-family:var(--mono);font-size:.78rem;color:var(--teal-ink);background:var(--teal-bright);
  border-radius:8px;padding:.25rem .55rem;font-weight:600;flex:none}
.rec b{display:block;font-size:.93rem;color:var(--txt)}
.rec p{font-size:.82rem;color:var(--txt-mute);margin:.2rem 0 0}
.report-meta{font-family:var(--mono);font-size:.7rem;color:var(--txt-mute);letter-spacing:.05em}

/* ---------- settings ---------- */
.set-rows{display:flex;flex-direction:column}
.set-row{display:flex;justify-content:space-between;gap:1rem;padding:.75rem 0;
  border-bottom:1px solid var(--line-soft);font-size:.93rem;flex-wrap:wrap}
.set-row span{color:var(--txt-mute)}
.set-row b{color:var(--txt);font-weight:600}
.set-row a{color:var(--teal-bright)}
.btn-mini{border:1px solid var(--line);border-radius:999px;padding:.3rem .9rem;
  font-size:.8rem;color:var(--txt-soft)}
.btn-mini:hover{border-color:var(--teal-bright);color:#fff}

/* ---------- responsive ---------- */
@media (max-width:1080px){
  .kpis{grid-template-columns:1fr 1fr}
  .ov-grid{grid-template-columns:1fr}
}
@media (max-width:880px){
  .login-split{grid-template-columns:1fr}
  .login-visual{min-height:38vh}
  .app-shell{grid-template-columns:1fr}
  .side{position:fixed;bottom:0;top:auto;left:0;right:0;height:auto;z-index:50;
    flex-direction:row;align-items:center;padding:.5rem .8rem;
    border-top:1px solid var(--line);border-right:0}
  .brand-side,.side-foot{display:none}
  .side-nav{flex-direction:row;justify-content:space-around;width:100%}
  .side-nav button{flex-direction:column;gap:.25rem;font-size:.62rem;padding:.45rem .5rem}
  .nav-pill{display:none}
  .main{padding-bottom:6.5rem}
}
@media (max-width:560px){
  .kpis{grid-template-columns:1fr 1fr;gap:.7rem}
  .kpi-num{font-size:1.7rem}
  .stack{grid-template-columns:repeat(3,1fr)}
  .topbar h1{font-size:1.5rem}
}
