:root{
  --bg:#eaf1f8;
  --surface:#ffffff;
  --surface-soft:#f7f8fa;
  --text:#17202a;
  --muted:#657181;
  --brand:#1f4d5a;
  --brand-strong:#173a44;
  --accent:#2f766f;
  --danger:#b42318;
  --border:#d9dee5;
  --ring:rgba(47,118,111,.2);
  --doctor-bg:#fff1f5;
  --doctor-border:#f4b8ca;
  --doctor-text:#9f2d55;
  --cliente-bg:#eefaf2;
  --cliente-border:#a8ddb8;
  --cliente-text:#246b3d;
  --prep-bg:#eef6ff;
  --prep-border:#b8d7f2;
  --prep-text:#235f8f;
  --comp-bg:#f5f0ff;
  --comp-border:#c9b6ee;
  --comp-text:#5b3b9a;
  --shadow:0 14px 34px rgba(29,54,77,.08);
}

*{box-sizing:border-box}

html{background:var(--bg)}

body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:
    linear-gradient(180deg,#f4f9ff 0,#eaf1f8 340px);
  color:var(--text);
  line-height:1.5;
  font-size:13px;
}

body.home-page{
  min-height:100vh;
  background:
    radial-gradient(circle at 20% 0,#ffffff 0,#e7f7ff 34%,#d7eefc 100%);
}

a{color:var(--brand);text-decoration:none}
a:hover{color:var(--accent)}

.container{
  max-width:1240px;
  margin:0 auto;
  padding:24px;
}

.card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:8px;
  padding:22px;
  box-shadow:var(--shadow);
}

.home-container{
  max-width:980px;
  padding-top:36px;
}

.home-card{
  border-color:#b8def2;
  background:rgba(255,255,255,.9);
}

.brand-header{
  display:flex;
  align-items:center;
  gap:18px;
  padding-bottom:18px;
  border-bottom:1px solid #d4e9f5;
}

.brand-logo-img{
  width:360px;
  max-width:46%;
  height:auto;
  object-fit:contain;
  display:block;
}

.home-subtitle{
  margin:7px 0 0;
  color:#506477;
  font-size:13px;
}

.home-nav .btn{
  background:#f7fcff;
  border-color:#c9e3f2;
}

.home-nav .home-btn-preparado:hover{
  background:#dff7e7;
  border-color:#8fd6a6;
  color:#1f6b38;
  box-shadow:0 8px 18px rgba(50,140,82,.16);
}

.home-nav .home-btn-listado:hover{
  background:#dff4ff;
  border-color:#8fd2f2;
  color:#176385;
  box-shadow:0 8px 18px rgba(31,118,158,.16);
}

.home-nav .home-btn-thc:hover{
  background:#ecf9ef;
  border-color:#91d5a1;
  color:#246b3d;
  box-shadow:0 8px 18px rgba(36,107,61,.15);
}

.home-nav .home-btn-doctores:hover{
  background:#ffe3ed;
  border-color:#f4a9c1;
  color:#9f2d55;
  box-shadow:0 8px 18px rgba(159,45,85,.14);
}

.home-nav .home-btn-pacientes:hover{
  background:#2f7658;
  border-color:#2f7658;
  color:#fff;
  box-shadow:0 8px 18px rgba(47,118,88,.2);
}

.home-nav .home-btn-componentes:hover{
  background:#eee4ff;
  border-color:#b89bea;
  color:#5b3b9a;
  box-shadow:0 8px 18px rgba(91,59,154,.16);
}

body.module-preparado{
  --module-bg:#edf9f1;
  --module-soft:#f6fff8;
  --module-border:#9edbb2;
  --module-text:#247243;
  --module-shadow:rgba(36,114,67,.12);
  background:linear-gradient(180deg,#f8fffa 0,#edf9f1 340px);
}

body.module-listado{
  --module-bg:#eaf7ff;
  --module-soft:#f7fcff;
  --module-border:#9fd6f4;
  --module-text:#176385;
  --module-shadow:rgba(23,99,133,.12);
  background:linear-gradient(180deg,#f7fcff 0,#eaf7ff 340px);
}

body.module-thc{
  --module-bg:#eef9f1;
  --module-soft:#f8fff9;
  --module-border:#91d5a1;
  --module-text:#246b3d;
  --module-shadow:rgba(36,107,61,.14);
  background:linear-gradient(180deg,#f8fff9 0,#eef9f1 340px);
}

.module-note{
  display:inline-block;
  margin:0 0 12px;
  padding:8px 10px;
  border:1px solid var(--module-border);
  border-radius:6px;
  background:var(--module-soft);
  color:var(--module-text);
  font-weight:700;
}

.thc-list-head{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:12px;
}

.thc-list-head h2,
.thc-list-head .module-note{
  margin:0;
}

.thc-list-head .module-note{
  padding:7px 10px;
}

body.module-listado.module-thc .btn.btn-back{
  margin-left:auto;
  background:#e7f1ff;
  border-color:#8eb9ef;
  color:#1656a3;
}

body.module-listado.module-thc .btn.btn-back:hover{
  background:#1656a3;
  border-color:#1656a3;
  color:#fff;
}

body.module-doctores{
  --module-bg:#fff1f6;
  --module-soft:#fff8fb;
  --module-border:#f3abc3;
  --module-text:#9f2d55;
  --module-shadow:rgba(159,45,85,.12);
  background:linear-gradient(180deg,#fff9fb 0,#fff1f6 340px);
}

body.module-pacientes{
  --module-bg:#e7f3ee;
  --module-soft:#f4fbf8;
  --module-border:#7fbd9f;
  --module-text:#255f47;
  --module-shadow:rgba(37,95,71,.14);
  background:linear-gradient(180deg,#f4fbf8 0,#e7f3ee 340px);
}

body.module-componentes{
  --module-bg:#f4efff;
  --module-soft:#fbf8ff;
  --module-border:#bca4ea;
  --module-text:#5b3b9a;
  --module-shadow:rgba(91,59,154,.13);
  background:linear-gradient(180deg,#fbf8ff 0,#f4efff 340px);
}

body.module-preparado .card,
body.module-listado .card,
body.module-doctores .card,
body.module-pacientes .card,
body.module-componentes .card{
  border-color:var(--module-border);
  background:rgba(255,255,255,.92);
  box-shadow:0 14px 34px var(--module-shadow);
}

body.module-preparado h2,
body.module-listado h2,
body.module-doctores h2,
body.module-pacientes h2,
body.module-componentes h2{
  color:var(--module-text);
}

body.module-preparado .btn,
body.module-listado .btn,
body.module-doctores .btn,
body.module-pacientes .btn,
body.module-componentes .btn{
  background:var(--module-soft);
  border-color:var(--module-border);
}

body.module-preparado .btn:hover,
body.module-listado .btn:hover,
body.module-doctores .btn:hover,
body.module-pacientes .btn:hover,
body.module-componentes .btn:hover{
  background:var(--module-text);
  border-color:var(--module-text);
  color:#fff;
  box-shadow:0 8px 18px var(--module-shadow);
}

body.module-pacientes .btn:hover{
  background:#255f47;
  border-color:#255f47;
}

body.module-preparado .table,
body.module-listado .table,
body.module-doctores .table,
body.module-pacientes .table,
body.module-componentes .table{
  border-color:var(--module-border);
}

body.module-preparado .table th,
body.module-listado .table th,
body.module-doctores .table th,
body.module-pacientes .table th,
body.module-componentes .table th{
  background:var(--module-soft);
  color:var(--module-text);
}

body.module-preparado .input:focus,
body.module-preparado select:focus,
body.module-preparado textarea:focus,
body.module-listado .input:focus,
body.module-listado select:focus,
body.module-listado textarea:focus,
body.module-doctores .input:focus,
body.module-doctores select:focus,
body.module-doctores textarea:focus,
body.module-pacientes .input:focus,
body.module-pacientes select:focus,
body.module-pacientes textarea:focus,
body.module-componentes .input:focus,
body.module-componentes select:focus,
body.module-componentes textarea:focus{
  border-color:var(--module-border);
  box-shadow:0 0 0 4px var(--module-shadow);
}

h1,h2,h3{
  color:var(--text);
  line-height:1.15;
  letter-spacing:0;
}

h1{
  margin:0;
  font-size:25px;
  font-weight:750;
}

h2{
  margin:20px 0 18px;
  font-size:21px;
  font-weight:740;
}

h3{
  margin:26px 0 14px;
  padding-top:18px;
  border-top:1px solid var(--border);
  font-size:15px;
  font-weight:720;
  color:var(--brand-strong);
}

.nav{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:12px;
}

.btn{
  min-height:36px;
  padding:8px 12px;
  border-radius:8px;
  border:1px solid var(--border);
  background:var(--surface);
  color:var(--text);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font:inherit;
  font-weight:650;
  line-height:1.2;
  transition:background-color .15s ease,border-color .15s ease,color .15s ease,box-shadow .15s ease,transform .15s ease;
  cursor:pointer;
  white-space:normal;
}

.btn:hover{
  background:var(--brand);
  color:#fff;
  border-color:var(--brand);
  box-shadow:0 8px 18px rgba(31,77,90,.18);
  transform:translateY(-1px);
}

.btn-danger:hover{
  background:var(--danger)!important;
  border-color:var(--danger)!important;
  color:#fff!important;
}

.btn:focus-visible,
.input:focus,
select:focus,
textarea:focus{
  outline:0;
  border-color:var(--accent);
  box-shadow:0 0 0 4px var(--ring);
}

form{margin:0}

.grid{display:grid;gap:12px}

form > .grid{
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
}

form > .grid > div{
  padding:9px;
  border:1px solid var(--prep-border);
  border-radius:8px;
  background:var(--prep-bg);
}

form > .grid > div:nth-child(-n+4){
  border-color:var(--doctor-border);
  background:var(--doctor-bg);
}

form > .grid > div:nth-child(-n+4) .label{
  color:var(--doctor-text);
}

form > .grid > div:nth-child(n+5):nth-child(-n+8){
  border-color:var(--cliente-border);
  background:var(--cliente-bg);
}

form > .grid > div:nth-child(n+5):nth-child(-n+8) .label{
  color:var(--cliente-text);
}

form > .grid > div:nth-child(n+9) .label{
  color:var(--prep-text);
}

form > .grid{
  align-items:end;
}

.input,
select,
textarea{
  width:100%;
  min-height:32px;
  padding:7px 9px;
  border-radius:8px;
  border:1px solid var(--border);
  background:var(--surface);
  color:var(--text);
  font:inherit;
  transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease;
}

select{
  appearance:auto;
  cursor:pointer;
}

.input:hover,
select:hover,
textarea:hover{
  border-color:#b7c0ca;
}

.label{
  font-size:11px;
  font-weight:700;
  color:var(--muted);
  margin-bottom:5px;
  text-transform:uppercase;
  letter-spacing:.04em;
}

.uppercase-name{
  text-transform:uppercase;
}

.row-comp{
  padding:10px;
  border:1px solid var(--comp-border);
  border-radius:8px;
  background:var(--comp-bg);
  box-shadow:0 1px 0 rgba(23,32,42,.04);
}

.row-comp .label,
h3{
  color:var(--comp-text);
}

.preparado-form h3{
  margin:16px 0 10px;
  font-size:15px;
}

.preparado-layout{
  display:grid;
  grid-template-columns:minmax(420px,1fr) minmax(390px,.92fr);
  gap:18px;
  align-items:start;
}

.form-panel{
  border:1px solid var(--border);
  border-radius:8px;
  background:#fbfdff;
  padding:14px;
}

.datos-panel{
  border-color:#bddcf0;
  background:#f5fbff;
}

.componentes-panel{
  border-color:var(--comp-border);
  background:#fbf7ff;
  position:sticky;
  top:12px;
}

.form-grid-2{
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}

.grid-full{
  grid-column:1 / -1;
}

.panel-title-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:12px;
}

.panel-title-row h3{
  margin:0;
}

.componentes-rows{
  display:grid;
  gap:10px;
}

.componente-row{
  display:grid;
  grid-template-columns:minmax(170px,1.6fr) minmax(80px,.7fr) minmax(100px,.8fr) minmax(110px,.9fr) auto;
  align-items:end;
  gap:8px;
}

.component-summary{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:14px;
}

.component-summary .summary-wide{
  grid-column:1 / -1;
}

.component-summary > div{
  border:1px solid var(--comp-border);
  border-radius:8px;
  background:#fff;
  padding:12px;
}

.component-summary span{
  display:block;
  color:var(--muted);
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.04em;
}

.component-summary strong{
  display:block;
  margin-top:6px;
  color:var(--comp-text);
  font-size:20px;
}

.input-total{
  font-weight:800;
  color:#176385;
  background:#eef8ff;
}

.form-actions{
  margin-top:16px;
  display:flex;
  justify-content:flex-end;
}

.create-preparado-page{
  font-size:12px;
  line-height:1.25;
}

.create-preparado-page .container{
  max-width:1460px;
  padding:6px 10px;
}

.create-preparado-page .card{
  padding:10px 12px;
  zoom:.86;
}

.create-preparado-page h2{
  margin:4px 0 6px;
  font-size:20px;
}

.create-preparado-page .btn{
  min-height:28px;
  padding:5px 9px;
  border-radius:6px;
}

.create-preparado-page .preparado-layout{
  grid-template-columns:minmax(0,1.42fr) minmax(0,.78fr);
  gap:10px;
}

.create-preparado-page .form-panel{
  padding:6px;
}

.create-preparado-page .preparado-form h3{
  margin:6px 0 3px;
  font-size:14px;
}

.create-preparado-page .grid{
  gap:4px;
}

.create-preparado-page .form-grid-2{
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:4px 7px;
}

.create-preparado-page .form-grid-4{
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:4px 7px;
}

.create-preparado-page .label{
  font-size:9.5px;
  margin-bottom:1px;
  letter-spacing:.025em;
}

.create-preparado-page .input,
.create-preparado-page select,
.create-preparado-page textarea{
  min-height:27px;
  padding:4px 7px;
  border-radius:6px;
}

.create-preparado-page .panel-title-row{
  margin-bottom:6px;
}

.create-preparado-page .upload-receta-box{
  display:grid;
  grid-template-columns:auto 1fr;
  align-items:center;
  gap:5px 8px;
  margin-bottom:7px;
}

.create-preparado-page .upload-receta-box .label{
  grid-column:1 / -1;
}

.create-preparado-page .upload-receta-box .file-note{
  margin:0;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

.create-preparado-page .componentes-rows{
  gap:6px;
}

.componentes-header{
  display:grid;
  grid-template-columns:minmax(0,1.45fr) minmax(68px,.55fr) minmax(78px,.65fr) 30px;
  gap:6px;
  align-items:end;
  margin-bottom:4px;
  color:var(--comp-text);
  font-size:9.5px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.025em;
}

.create-preparado-page .row-comp{
  padding:5px;
  border-radius:6px;
}

.create-preparado-page .componente-row{
  grid-template-columns:minmax(0,1.45fr) minmax(68px,.55fr) minmax(78px,.65fr) 30px;
  gap:6px;
}

.create-preparado-page .comp-field-name{
  grid-column:auto;
}

.create-preparado-page .del-comp{
  width:30px;
  min-width:30px;
  padding:0;
  font-size:16px;
  line-height:1;
}

.create-preparado-page .component-summary{
  gap:6px;
  margin-top:8px;
}

.create-preparado-page .component-summary > div{
  padding:6px 8px;
  border-radius:6px;
}

.create-preparado-page .component-summary span{
  font-size:9.5px;
}

.create-preparado-page .component-summary strong{
  margin-top:2px;
  font-size:17px;
}

.create-preparado-page .form-actions{
  margin-top:8px;
}

.table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:8px;
  overflow:hidden;
}

.table th,
.table td{
  padding:12px 14px;
  border-bottom:1px solid var(--border);
  text-align:left;
  vertical-align:middle;
}

.table th{
  background:var(--surface-soft);
  font-size:12px;
  font-weight:750;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.04em;
}

.table tr:last-child td{border-bottom:0}
.table tbody tr:hover{background:#f9fafb}

.componentes-cell{
  max-width:280px;
  font-size:10px;
  line-height:1.28;
  color:#405162;
}

.receta-cell{
  width:70px;
  text-align:center;
}

.receta-cell img{
  width:42px;
  height:42px;
  object-fit:cover;
  border:1px solid var(--border);
  border-radius:6px;
  background:#fff;
  display:block;
}

.pdf-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border:1px solid #f1a7a7;
  border-radius:6px;
  background:#fff0f0;
  color:#b42318;
  font-size:12px;
  font-weight:900;
}

.muted-cell{
  color:#8a96a3;
  font-size:11px;
}

.file-note{
  margin-top:5px;
  font-size:11px;
  font-weight:700;
}

.valores-cell{
  min-width:105px;
  font-size:11px;
  line-height:1.35;
}

.valores-cell div{
  display:flex;
  justify-content:space-between;
  gap:8px;
  white-space:nowrap;
}

.valores-cell span{
  color:var(--muted);
  font-weight:700;
}

.estado-cell{
  min-width:118px;
}

.estado-select{
  min-height:30px;
  padding:5px 8px;
  border-radius:6px;
  font-size:12px;
  font-weight:800;
}

.estado-cotizado{
  background:#fff8e8;
  border-color:#efc66c;
  color:#8a5b00;
}

.estado-fabricación{
  background:#f4efff;
  border-color:#bea8ee;
  color:#5b3b9a;
}

.estado-terminado{
  background:#e8f3ff;
  border-color:#94c4ef;
  color:#1f6aa5;
}

.estado-entregado{
  background:#e9f8ef;
  border-color:#8fd6a6;
  color:#247243;
}

.estado-error{
  border-color:#d92d20;
  box-shadow:0 0 0 3px rgba(217,45,32,.14);
}

.file-input-hidden{
  position:absolute;
  width:1px;
  height:1px;
  opacity:0;
  pointer-events:none;
}

.upload-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:30px;
  padding:6px 11px;
  border:1px solid #8fd6a6;
  border-radius:6px;
  background:#e9f8ef;
  color:#247243;
  font-weight:800;
  cursor:pointer;
}

.upload-btn:hover{
  background:#247243;
  border-color:#247243;
  color:#fff;
}

.money-cell{
  text-align:right;
  white-space:nowrap;
  font-variant-numeric:tabular-nums;
}

.money-total{
  font-weight:750;
  color:var(--module-text, var(--brand));
}

.badge{
  display:inline-flex;
  align-items:center;
  min-height:22px;
  padding:2px 8px;
  border-radius:999px;
  background:#edf2f7;
  color:#405162;
  font-size:11px;
  font-weight:750;
}

.badge-danger{
  background:#fff0f0;
  color:#b42318;
}

.list-actions{
  margin-top:10px;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.list-filter-form{
  margin-top:12px;
  padding:10px;
  display:grid;
  grid-template-columns:minmax(120px, 1fr) minmax(140px, 1fr) minmax(120px, .8fr) minmax(120px, .8fr) minmax(130px, .85fr) auto;
  gap:8px;
  align-items:end;
  border:1px solid var(--module-border, var(--border));
  border-radius:8px;
  background:var(--module-soft, #f8fafc);
}

.list-filter-form > div:not(.filter-actions){
  min-width:0;
}

.list-filter-form .label{
  margin-bottom:4px;
}

.filter-actions{
  display:flex;
  gap:8px;
  align-items:center;
}

.actions-cell{
  white-space:normal;
  min-width:102px;
  width:102px;
  max-width:102px;
  line-height:0;
}

.icon-btn{
  width:28px;
  height:28px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin:3px;
  border:1px solid var(--module-border, var(--border));
  border-radius:7px;
  background:var(--module-soft, #fff);
  color:var(--module-text, var(--text));
  font-size:14px;
  font-weight:800;
  line-height:1;
}

.icon-btn img{
  width:17px;
  height:17px;
  display:block;
}

.icon-btn:hover{
  background:var(--module-text, var(--brand));
  color:#fff;
  border-color:var(--module-text, var(--brand));
}

.icon-edit{background:#e8f2ff;border-color:#9bc7f2;color:#1f6aa5}
.icon-fabricacion{background:#f5f0ff;border-color:#c0a8ef;color:#5b3b9a}
.icon-despacho{background:#e9f8ef;border-color:#90d3a8;color:#247243}
.icon-etiqueta{background:#fff4df;border-color:#f0bf67;color:#a56405}
.icon-detalle{background:#eff6ff;border-color:#8ec5ff;color:#175cd3}
.icon-danger{background:#fff0f0;border-color:#f1a7a7;color:#b42318}

.icon-edit:hover{background:#1f6aa5;border-color:#1f6aa5;color:#fff}
.icon-fabricacion:hover{background:#5b3b9a;border-color:#5b3b9a;color:#fff}
.icon-despacho:hover{background:#247243;border-color:#247243;color:#fff}
.icon-etiqueta:hover{background:#a56405;border-color:#a56405;color:#fff}
.icon-detalle:hover{background:#175cd3;border-color:#175cd3;color:#fff}

.icon-danger:hover{
  background:var(--danger);
  border-color:var(--danger);
  color:#fff;
}

.autocomplete-wrap{position:relative}

.autocomplete-list{
  position:absolute;
  top:calc(100% + 6px);
  left:0;
  right:0;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:8px;
  z-index:20;
  box-shadow:0 18px 34px rgba(23,32,42,.14);
  max-height:240px;
  overflow:auto;
}

.autocomplete-item{
  padding:10px 12px;
  cursor:pointer;
  color:var(--text);
}

.autocomplete-item:hover{
  background:#edf6f4;
  color:var(--brand-strong);
}

.print-area{page-break-inside:avoid}

.session-bar{
  display:flex;
  justify-content:flex-end;
  align-items:center;
  gap:10px;
  margin-bottom:10px;
  color:#4d6070;
  font-size:12px;
}

.session-bar a{
  color:#176385;
  font-weight:700;
  text-decoration:none;
}

.login-page{
  min-height:100vh;
  background:linear-gradient(180deg,#dff3ff 0%,#eef9ff 100%);
}

.login-shell{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
}

.login-card{
  width:min(420px,100%);
  background:#fff;
  border:1px solid #bde1f4;
  border-radius:8px;
  box-shadow:0 22px 55px rgba(36,88,112,.16);
  padding:28px;
}

.login-logo{
  display:block;
  width:260px;
  max-width:100%;
  margin:0 auto 18px;
}

.login-card h1{
  margin:0;
  text-align:center;
  font-size:24px;
}

.login-card p{
  margin:6px 0 20px;
  text-align:center;
  color:#4d6070;
}

.login-form{
  display:grid;
  gap:14px;
}

.login-form label{
  display:grid;
  gap:6px;
  color:#30485a;
  font-weight:700;
}

.login-form input{
  width:100%;
  border:1px solid var(--border);
  border-radius:6px;
  padding:10px 12px;
  font:inherit;
}

.alert-error{
  margin-bottom:14px;
  padding:10px 12px;
  border:1px solid #f1a7a7;
  border-radius:6px;
  background:#fff0f0;
  color:#b42318;
  font-weight:700;
}

.label-101x34{
  width:101mm;
  height:34mm;
  padding:3mm 4mm;
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:6px;
  font-size:10px;
  line-height:1.2;
  border:.45mm solid #111;
  background:#fff;
  color:#000;
}

.label-101x34 .ff{font-weight:700}
.label-101x34 .rojo-small{color:#d00;font-weight:700;font-size:8px}
.label-101x34 .azul{color:#004f9e;font-weight:600}
.control-star{height:5mm;font-size:5mm;line-height:5mm;text-align:center;font-family:Arial,Helvetica,sans-serif}
.star-green{color:#168a3a}
.star-red{color:#d00000}

.footer-azul{
  grid-column:1 / -1;
  align-self:end;
  color:#004f9e;
  font-size:8px;
  line-height:1.2;
  margin-top:2px;
  text-align:center;
}

.comp{font-size:9px;line-height:1.2;white-space:pre}
.comp-name{display:inline-block;width:10ch;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}
.qty{display:inline-block;width:3ch;text-align:right}

.label-101x34.cannabis-label{
  padding:1.5mm 2mm 0;
  display:flex;
  flex-direction:column;
  gap:0;
  border:.45mm solid #062333;
  font-size:8.4px;
  line-height:1.13;
  overflow:hidden;
}

.label-101x34 .cannabis-main{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:2mm;
  flex:1;
  min-height:0;
}

.label-101x34 .cannabis-left,
.label-101x34 .cannabis-dose,
.label-101x34 .cannabis-right{min-width:0}

.label-101x34 .cannabis-left{padding-top:.2mm}

.label-101x34 .cannabis-logo{
  width:24mm;
  height:7mm;
  object-fit:contain;
  object-position:left center;
  display:block;
  margin-bottom:.8mm;
}

.label-101x34 .copy-label{
  display:inline-block;
  margin-bottom:.4mm;
  padding:.2mm 1mm;
  border:1px solid #2f7fa9;
  border-radius:2px;
  color:#155c82;
  font-size:6.6px;
  font-weight:800;
  text-transform:uppercase;
}

.label-101x34 .cannabis-dose{
  border-left:.3mm solid #0f73b7;
  border-right:.3mm solid #0f73b7;
  text-align:center;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:.45mm;
  font-size:7.6px;
  line-height:1.08;
}

.label-101x34 .cannabis-star{
  color:#e81925;
  font-size:13mm;
  line-height:10mm;
}

.label-101x34 .cannabis-warning{
  color:#e00000;
  font-weight:700;
  font-size:5.8px;
  line-height:1.05;
}

.label-101x34 .rp-line{
  margin-top:.4mm;
  font-size:6.2px;
  font-weight:700;
  color:#111;
}

.label-101x34 .grandiosa-logo{
  width:26mm;
  height:8mm;
  object-fit:contain;
  object-position:left center;
  display:block;
  margin-bottom:.8mm;
}

.label-101x34 .cannabis-footer{
  margin:0 -2mm;
  height:7.6mm;
  color:#fff;
  text-align:center;
  font-size:6.4px;
  line-height:1.15;
  padding:1mm 2mm;
}

.label-101x34.footer-vet .cannabis-footer{background:#0c82c9}
.label-101x34.footer-thc .cannabis-footer{background:#ffc400;color:#111}
.label-101x34.footer-cbd .cannabis-footer{background:#115c4f}

.label-101x34,
.label-101x34 *{
  -webkit-print-color-adjust:exact;
  print-color-adjust:exact;
}

@media (max-width:900px){
  .container{padding:18px}
  .card{padding:20px}
  .preparado-layout{grid-template-columns:1fr}
  .componentes-panel{position:static}
  .componente-row{grid-template-columns:1fr 1fr}
  form > .grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  .row-comp.grid{grid-template-columns:1fr 1fr!important}
  .list-filter-form{grid-template-columns:repeat(2,minmax(0,1fr))}
  .filter-actions{grid-column:1 / -1}
  .table{display:block;overflow-x:auto}
  .brand-header{align-items:flex-start}
  .brand-logo-img{width:300px}
}

@media (max-width:520px){
  body{font-size:13px}
  .container{padding:12px}
  .card{padding:16px}
  h1{font-size:24px}
  h2{font-size:21px}
  form > .grid,
  .grid,
  .row-comp.grid{grid-template-columns:1fr!important}
  .form-grid-2,
  .list-filter-form,
  .componente-row,
  .component-summary{grid-template-columns:1fr}
  .nav .btn,
  form button.btn{width:100%}
  .brand-header{display:block}
  .brand-logo-img{max-width:100%;margin-bottom:14px}
}

@media print{
  body{background:#fff;color:#000}
  .container{padding:0}
  .card{box-shadow:none;border:0;padding:0}
  .no-print{display:none}
  .label-101x34{border:.45mm solid #111}
  .label-101x34.cannabis-label{border:.45mm solid #062333}
}
