/* ==========================================================================
   MT Clinical OS — identidad visual Dra. Magdalena Tempesta
   ========================================================================== */
:root{
  --bordo1:#3D1419;      /* bordó profundo — texto / elementos fuertes */
  --bordo2:#65333B;      /* bordó medio */
  --rosa:#DAACA6;        /* rosa — acento */
  --nude:#D6BDAD;        /* nude */
  --crema:#FBEDDC;       /* crema */
  --crema2:#F3E4D2;

  --page:#FBF4E9;        /* fondo cálido de la app */
  --surface:#FFFDF9;     /* blanco cálido de cards */
  --soft:#FBF2E3;        /* relleno suave */

  --ink:#3D1419;
  --muted:rgba(61,20,25,.56);
  --faint:rgba(61,20,25,.40);
  --line:rgba(101,51,59,.14);
  --line-strong:rgba(101,51,59,.24);

  --amber-bg:#F7E4C4;    --amber-tx:#8A4B12;
  --ok-bg:#E4EFDC;       --ok-tx:#4B6B2E;

  --radius:12px;
  --radius-sm:9px;
  --shadow-soft:0 18px 50px -28px rgba(61,20,25,.35);
  --sidebar-w:232px;

  --sans:'Jost',system-ui,sans-serif;
  --serif:'Fraunces',Georgia,serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--page);
  font-size:15px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
.boot{display:grid;place-items:center;height:100vh;color:var(--muted);font-size:14px}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
input,textarea,select{font-family:inherit}
.serif{font-family:var(--serif);font-weight:400;letter-spacing:-.012em}
.muted{color:var(--muted)}
i.ti{line-height:1}

/* ---------- Layout general ------------------------------------------------ */
.app-shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}

.sidebar{
  border-right:1px solid var(--line);
  padding:20px 14px;
  display:flex;flex-direction:column;gap:4px;
  position:sticky;top:0;height:100vh;
}
.brand{display:flex;align-items:center;gap:10px;padding:6px 8px 18px}
.brand .mark{
  width:30px;height:30px;border-radius:8px;background:var(--bordo1);color:var(--crema);
  display:grid;place-items:center;font-family:var(--serif);font-size:13px;font-weight:500;
}
.brand .mark img{width:100%;height:100%;object-fit:contain;padding:3px}
.brand .name{font-size:14px;font-weight:500}
.brand .name small{display:block;font-size:11px;color:var(--muted);font-weight:400;letter-spacing:.02em}

.nav-item{
  display:flex;align-items:center;gap:11px;
  padding:9px 11px;border-radius:var(--radius-sm);
  color:var(--muted);font-size:14px;transition:background .15s,color .15s;
}
.nav-item i{font-size:18px}
.nav-item:hover{background:var(--soft);color:var(--ink)}
.nav-item.active{background:var(--surface);color:var(--ink);font-weight:500;box-shadow:0 1px 0 var(--line)}
.sidebar-foot{margin-top:auto;display:flex;align-items:center;gap:10px;padding:10px 11px;color:var(--muted);font-size:13px;border-top:1px solid var(--line)}
.sidebar-foot .av{width:28px;height:28px;flex:none}

.main{min-width:0;display:flex;flex-direction:column}

/* ---------- Topbar -------------------------------------------------------- */
.topbar{
  position:sticky;top:0;z-index:20;
  display:flex;align-items:center;gap:14px;
  padding:14px 26px;background:rgba(251,244,233,.82);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line);
}
.searchbar{
  flex:1;max-width:520px;display:flex;align-items:center;gap:9px;
  background:var(--surface);border:1px solid var(--line);border-radius:24px;
  padding:9px 15px;color:var(--muted);font-size:13.5px;transition:border-color .15s;
}
.searchbar:focus-within{border-color:var(--line-strong)}
.searchbar i{font-size:17px}
.searchbar input{border:none;background:none;outline:none;flex:1;color:var(--ink);font-size:14px}
.searchbar input::placeholder{color:var(--faint)}
.kbd{border:1px solid var(--line);border-radius:5px;padding:1px 6px;font-size:11px;color:var(--muted)}
.topbar-menu{display:none}

/* ---------- Página -------------------------------------------------------- */
.page{padding:26px 26px 90px;max-width:1080px;width:100%;margin:0 auto}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:22px}
.page-head h1{font-family:var(--serif);font-size:26px;font-weight:400;letter-spacing:-.02em}
.page-head .sub{font-size:13px;color:var(--muted);margin-top:3px}
.section-label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin:0 0 10px}

/* ---------- Cards / métricas --------------------------------------------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px}
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:26px}
.metric{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:15px 16px}
.metric .k{font-size:12.5px;color:var(--muted)}
.metric .v{font-family:var(--serif);font-size:30px;font-weight:400;margin-top:4px;line-height:1}
.metric .v small{font-size:13px;color:var(--muted);font-family:var(--sans)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}

.mini{background:var(--soft);border-radius:var(--radius-sm);padding:11px 13px;font-size:13px;margin-bottom:8px}
.mini:last-child{margin-bottom:0}
.mini .t{font-weight:500}
.mini .d{color:var(--muted);font-size:12.5px;margin-top:2px}
.mini .ico{color:var(--bordo2);margin-right:7px}

/* ---------- Avatares / badges / pills ------------------------------------ */
.av{border-radius:50%;display:grid;place-items:center;font-weight:500;color:var(--bordo2);background:#EBD7C7;flex:none}
.av.lg{width:46px;height:46px;font-size:15px}
.av.md{width:36px;height:36px;font-size:12.5px}

.pill{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;padding:3px 10px;border-radius:20px;white-space:nowrap}
.pill i{font-size:13px}
.pill-medico{background:var(--amber-bg);color:var(--amber-tx)}
.pill-atencion{background:var(--bordo1);color:var(--crema)}
.pill-administrativo{background:#EBD7C7;color:var(--bordo2)}
.pill-caso{background:var(--rosa);color:var(--bordo1)}
.badge{font-size:11px;padding:3px 10px;border-radius:20px}
.badge-activo{background:var(--ok-bg);color:var(--ok-tx)}
.badge-pausa{background:var(--soft);color:var(--muted)}
.tag-menor{font-size:11px;color:var(--bordo2)}
.ref-tag{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;background:#F1E2D3;color:var(--bordo2);padding:2px 9px;border-radius:16px;white-space:nowrap;max-width:100%}
.ref-tag i{font-size:12px;flex:none}
.ref-tag span{overflow:hidden;text-overflow:ellipsis}
.ref-line{margin-top:7px;font-size:13px;color:var(--bordo2);display:inline-flex;align-items:center;gap:7px;flex-wrap:wrap}
.ref-line i{font-size:15px;color:var(--rosa)}
.ref-line a{color:var(--bordo1);border-bottom:1px solid var(--nude)}
.referidos-box{margin-top:18px}
.referidos-box a{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--bordo1);background:var(--soft);border:1px solid var(--line);border-radius:16px;padding:5px 12px;margin:0 6px 6px 0}

/* ---------- Lista de pacientes ------------------------------------------- */
.list{display:flex;flex-direction:column;gap:9px}
.prow{
  display:flex;align-items:center;gap:13px;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:12px 14px;transition:border-color .15s,transform .05s;
}
.prow:hover{border-color:var(--line-strong)}
.prow:active{transform:scale(.997)}
.prow.flagged{background:#FCF2E4;border-color:var(--line-strong)}
.prow .warn{font-size:18px;color:var(--bordo1);flex:none}
.prow .grow{flex:1;min-width:0}
.prow .nm{font-size:14px;font-weight:500;display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.prow .meta{font-size:12.5px;color:var(--muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.prow .side{font-size:12px;color:var(--muted);flex:none}

/* ---------- Ficha / tabs / banner ---------------------------------------- */
.flag-banner{background:var(--bordo1);color:var(--crema);border-radius:var(--radius);padding:13px 16px;display:flex;align-items:flex-start;gap:11px;margin-bottom:16px}
.flag-banner i{font-size:20px;color:var(--rosa);margin-top:1px}
.flag-banner .t{font-size:13.5px;font-weight:500}
.flag-banner .d{font-size:12.5px;color:rgba(251,237,220,.72);margin-top:3px;line-height:1.5}

.reminder-banner{background:#F3E1D3;border:1px solid var(--nude);border-radius:var(--radius);padding:11px 15px;display:flex;align-items:center;gap:11px;margin-bottom:10px;color:var(--bordo2);font-size:13.5px;line-height:1.4}
.reminder-banner:last-of-type{margin-bottom:16px}
.reminder-banner i{font-size:19px;color:var(--bordo2);flex:none}
.reminder-banner b{color:var(--bordo1);font-weight:500}

/* Badge de notificación en la navegación */
.nav-badge{margin-left:auto;background:var(--bordo1);color:var(--crema);font-size:11px;min-width:18px;height:18px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;padding:0 5px;font-weight:500}
.nav-dot{position:absolute;top:4px;right:calc(50% - 17px);width:8px;height:8px;border-radius:50%;background:var(--bordo1)}

.pt-head{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.pt-head .grow{flex:1;min-width:0}
.pt-head h1{font-family:var(--serif);font-size:23px;font-weight:400;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.pt-head .sub{font-size:12.5px;color:var(--muted);margin-top:3px}

.tabs{display:flex;gap:24px;border-bottom:1px solid var(--line);margin-bottom:20px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.tabs::-webkit-scrollbar{display:none}
.tab{padding:0 0 10px;font-size:14px;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;flex:none}
.tab.active{color:var(--ink);font-weight:500;border-color:var(--bordo1)}

/* ---------- Timeline ------------------------------------------------------ */
.timeline{position:relative;padding-left:20px}
.timeline::before{content:"";position:absolute;left:4px;top:6px;bottom:6px;width:1.5px;background:var(--line-strong)}
.tl-item{position:relative;margin-bottom:16px}
.tl-item::before{content:"";position:absolute;left:-20px;top:4px;width:9px;height:9px;border-radius:50%;background:var(--nude);border:2px solid var(--page)}
.tl-item.latest::before{background:var(--rosa)}
.tl-date{font-size:12px;color:var(--muted);margin-bottom:5px}
.tl-date b{color:var(--bordo2);font-weight:500}
.tl-body{background:var(--soft);border-radius:10px;padding:12px 14px;font-size:13.5px;line-height:1.6;white-space:pre-line}
.tl-body .lo{color:var(--muted)}
.chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px}
.chip{font-size:11.5px;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:2px 9px;color:var(--bordo2)}

/* ---------- Definiciones (Datos) ----------------------------------------- */
.dl{display:grid;grid-template-columns:repeat(2,1fr);gap:2px 20px}
.dl .row{display:flex;justify-content:space-between;gap:14px;padding:9px 0;border-bottom:1px solid var(--line);font-size:13.5px}
.dl .row .k{color:var(--muted)}
.dl .row .v{text-align:right}
.block-title{font-family:var(--serif);font-size:16px;margin:22px 0 8px}

/* ---------- Botones ------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;gap:7px;border-radius:22px;padding:9px 16px;font-size:13.5px;font-weight:500;border:1px solid var(--line-strong);background:var(--surface);color:var(--ink);transition:background .15s}
.btn i{font-size:16px}
.btn:hover{background:var(--soft)}
.btn-primary{background:var(--bordo1);color:var(--crema);border-color:var(--bordo1)}
.btn-primary:hover{background:#4d1a20}
.btn-block{width:100%;justify-content:center}
.fab{position:fixed;right:24px;bottom:86px;z-index:30;display:none}

/* ---------- Slide-over (nueva evolución) --------------------------------- */
.overlay{position:fixed;inset:0;background:rgba(61,20,25,.28);z-index:50;opacity:0;pointer-events:none;transition:opacity .2s}
.overlay.open{opacity:1;pointer-events:auto}
.panel{position:fixed;top:0;right:0;height:100vh;width:400px;max-width:92vw;background:var(--surface);z-index:60;box-shadow:var(--shadow-soft);transform:translateX(100%);transition:transform .24s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}
.panel.open{transform:none}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 12px}
.panel-head h3{font-family:var(--serif);font-size:19px;font-weight:400}
.panel-head .x{border:none;background:none;color:var(--muted);font-size:20px;padding:4px}
.panel-body{padding:0 20px 20px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:14px}
.field label{display:block;font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--faint);margin-bottom:6px}
.field input,.field textarea,.field select{
  width:100%;background:var(--soft);border:1px solid var(--line);border-radius:9px;
  padding:10px 12px;font-size:14px;color:var(--ink);outline:none;transition:border-color .15s;
}
.field textarea{min-height:74px;resize:vertical;line-height:1.5}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--rosa)}
.field-row{display:flex;gap:10px}
.field-row .field{flex:1}
.check{display:flex;align-items:center;gap:9px;font-size:14px}
.check input{width:17px;height:17px;accent-color:var(--bordo1)}
.panel-foot{padding:14px 20px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:10px}

/* ---------- Formulario de paciente --------------------------------------- */
.form-section{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;margin-bottom:16px}
.form-section > .fs-title{font-family:var(--serif);font-size:16px;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.form-section > .fs-title i{font-size:17px;color:var(--rosa)}
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px 14px}
.form-grid .full{grid-column:1/-1}
.ped-toggle{display:flex;align-items:center;gap:10px;font-size:14px;background:var(--soft);border-radius:var(--radius-sm);padding:11px 13px;margin-bottom:14px}
.ped-toggle input{width:18px;height:18px;accent-color:var(--bordo1)}
.marker-row{display:flex;gap:8px;align-items:center;margin-bottom:9px;flex-wrap:wrap}
.marker-row select{width:auto;min-width:120px}
.marker-row .mtext{flex:1;min-width:170px}
.marker-row .rm{padding:8px 10px;border-radius:9px}
.form-actions{display:flex;gap:10px;justify-content:flex-end;margin:6px 0 10px;position:sticky;bottom:0;background:var(--page);padding:12px 0}
.req{color:var(--bordo2)}
@media (max-width:860px){
  .form-actions .btn{flex:1;justify-content:center}
}

/* ---------- Tratamiento (cajas de alineadores) --------------------------- */
.trat-wrap{display:flex;flex-direction:column;gap:12px;max-width:620px}
.trat-hint2{font-size:12.5px;color:var(--muted);margin:-6px 0 2px}
.serv-list{display:flex;flex-direction:column;gap:8px}
.serv-item{display:flex;flex-direction:column;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:10px 12px}
.serv-item select,.serv-item input{background:var(--soft);border:1px solid var(--line);border-radius:9px;padding:8px 10px;font-size:13.5px;color:var(--ink);outline:none}
.serv-item select:focus,.serv-item input:focus{border-color:var(--rosa)}
.serv-main{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.serv-main select{min-width:160px}
.serv-main input[type=date]{width:150px}
.serv-main .btn{margin-left:auto}
.serv-item > input[type=text]{width:100%}
.serv-extra{display:flex;gap:12px;flex-wrap:wrap}
.serv-extra:empty{display:none}
.serv-f{display:flex;flex-direction:column;gap:4px;font-size:10.5px;color:var(--faint)}
.serv-f > span{letter-spacing:.06em;text-transform:uppercase}
.trat-caso{font-size:14px;color:var(--bordo2);display:flex;align-items:center;gap:7px}
.trat-caso i{color:var(--rosa);font-size:17px}
.trat-caso.muted{color:var(--muted)}
.trat-caso b{color:var(--bordo1);font-weight:500}
.trat-list{display:flex;flex-direction:column;gap:8px}
.trat-row{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:9px 12px}
.trat-caja-n{font-weight:500;font-size:13.5px;min-width:64px}
.trat-row input{width:88px;background:var(--soft);border:1px solid var(--line);border-radius:9px;padding:8px 10px;font-size:14px;color:var(--ink);outline:none}
.trat-row input:focus{border-color:var(--rosa)}
.trat-unit{color:var(--muted);font-size:13px;flex:1}
.trat-total{font-size:14px;font-weight:500}
.trat-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:6px;flex-wrap:wrap}

/* ---------- Odontograma --------------------------------------------------- */
.odo-wrap{display:flex;flex-direction:column;gap:14px}
.odo-tools{display:flex;flex-wrap:wrap;gap:16px}
.odo-group{min-width:0}
.odo-glabel{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin:0 0 6px}
.odo-chips{display:flex;flex-wrap:wrap;gap:6px}
.odo-chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:5px 11px;color:var(--ink);cursor:pointer;transition:border-color .15s,background .15s}
.odo-chip:hover{border-color:var(--line-strong)}
.odo-chip.active{border-color:var(--bordo1);background:var(--soft);box-shadow:inset 0 0 0 1px var(--bordo1)}
.odo-chip b{font-weight:500}
.odo-chip-l{color:var(--muted);font-size:11.5px}
.odo-dot{width:10px;height:10px;border-radius:50%;flex:none}
.odo-erase{color:var(--bordo2)}
.odo-hint{font-size:12.5px;color:var(--muted);background:var(--soft);border-radius:var(--radius-sm);padding:8px 12px}
.odo-chart{overflow-x:auto;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:10px}
.odo-svg{width:100%;min-width:620px;height:auto;display:block}
.odo-num{font-size:9px;fill:var(--bordo2);text-anchor:middle;font-family:var(--sans)}
.odo-letter{font-size:7px;text-anchor:middle;dominant-baseline:central;font-family:var(--sans);font-weight:500;pointer-events:none}
.odo-whole{font-size:9px;text-anchor:middle;font-family:var(--sans);font-weight:500}
.odo-actions{display:flex;align-items:center;justify-content:flex-end;gap:12px}
.odo-status{font-size:13px;color:var(--muted)}
@media (max-width:860px){
  .odo-chip-l{display:none}
  .odo-tools{gap:12px}
}

/* ---------- Login --------------------------------------------------------- */
.login{min-height:100vh;display:grid;place-items:center;padding:24px;
  background:radial-gradient(120% 90% at 50% -10%, #FDF6EC 0%, var(--page) 55%)}
.login-card{width:100%;max-width:380px;text-align:center}
.login .mark{width:60px;height:60px;border-radius:16px;background:var(--bordo1);color:var(--crema);display:grid;place-items:center;font-family:var(--serif);font-size:20px;margin:0 auto 20px}
.login .mark img{width:100%;height:100%;object-fit:contain;padding:8px}
.login h1{font-family:var(--serif);font-size:25px;font-weight:400}
.login .sub{color:var(--muted);font-size:13.5px;margin:6px 0 26px}
.login .field{text-align:left;margin-bottom:14px}
.login .demo-note{margin-top:18px;font-size:12px;color:var(--faint);line-height:1.5}
.login form{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:24px;box-shadow:var(--shadow-soft)}

/* ---------- Empty / util -------------------------------------------------- */
.empty{text-align:center;color:var(--muted);padding:40px 20px;font-size:13.5px}
.empty i{font-size:26px;display:block;margin-bottom:8px;color:var(--faint)}

/* ---------- Bottom nav (mobile) ------------------------------------------ */
.bottom-nav{display:none}

/* ---------- Responsive ---------------------------------------------------- */
@media (max-width:860px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{display:none}
  .topbar{padding:12px 16px}
  .topbar-menu{display:grid;place-items:center;width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:var(--surface);color:var(--ink);font-size:18px}
  .page{padding:18px 16px 96px}
  .metrics{grid-template-columns:1fr 1fr;gap:10px}
  .grid-2{grid-template-columns:1fr}
  .dl{grid-template-columns:1fr}
  .page-head h1{font-size:22px}
  .fab{display:inline-flex}
  .bottom-nav{
    display:flex;position:fixed;bottom:0;left:0;right:0;z-index:40;
    background:rgba(255,253,249,.94);backdrop-filter:blur(10px);
    border-top:1px solid var(--line);padding:8px 6px calc(8px + env(safe-area-inset-bottom));
    justify-content:space-around;
  }
  .bottom-nav a{position:relative;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10.5px;color:var(--muted);padding:4px 14px;border-radius:10px}
  .bottom-nav a i{font-size:21px}
  .bottom-nav a.active{color:var(--bordo1)}
}
