@import"https://fonts.googleapis.com/css2?family=Archivo:wght@500;600;700;800&family=Urbanist:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Archivo:wght@600;700;800&family=Urbanist:wght@500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Archivo:wght@600;700;800&family=Urbanist:wght@400;500;600;700&display=swap";.login-page{--brand-cyan: #35c9c4;--brand-cyan-dark: #20b4af;--brand-navy: #0b2f49;--ink-soft: #4f6472;--surface: #f4fbfc;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden;background:radial-gradient(1100px 620px at 15% 10%,rgb(53 201 196 / .2),transparent 62%),radial-gradient(900px 540px at 88% 90%,rgb(11 47 73 / .18),transparent 64%),linear-gradient(130deg,#d8f5f4,#dcefff 46%,#f4f8fd)}.login-page:before,.login-page:after{content:"";position:absolute;border-radius:999px;z-index:0;pointer-events:none}.login-page:before{width:520px;height:520px;background:linear-gradient(135deg,#35c9c44d,#35c9c408);top:-220px;right:-180px;animation:loginDrift 13s ease-in-out infinite}.login-page:after{width:420px;height:420px;background:linear-gradient(135deg,#0b2f492e,#0b2f490a);bottom:-170px;left:-110px;animation:loginDrift 15s ease-in-out infinite reverse}.login-container{width:min(1080px,100%);min-height:620px;display:grid;grid-template-columns:1.1fr minmax(340px,420px);background:#ffffff9e;border-radius:28px;border:1px solid rgb(255 255 255 / .9);box-shadow:0 28px 56px #122b3f2b;overflow:hidden;position:relative;z-index:1}.login-brand-panel{padding:clamp(2.2rem,4vw,3.5rem);background:linear-gradient(155deg,#ffffffb3,#ffffff40),linear-gradient(130deg,#35c9c43d,#35c9c414);display:flex;flex-direction:column;justify-content:center;gap:1.1rem;animation:loginEnter .62s cubic-bezier(.2,.7,.2,1) both}.brand-kicker{display:inline-flex;align-self:flex-start;padding:.4rem .78rem;border-radius:999px;background:#0b2f491a;color:var(--brand-navy);font-family:Urbanist,sans-serif;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;font-weight:700}.brand-logo{display:flex;align-items:flex-end;gap:.9rem;line-height:1}.brand-hi{font-family:Archivo,sans-serif;font-weight:800;font-size:clamp(3.1rem,6.4vw,4.8rem);color:var(--brand-navy);position:relative}.brand-hi:after{content:"";position:absolute;width:10px;height:78%;right:-9px;bottom:-8px;border-radius:999px;background:var(--brand-cyan)}.brand-wording{display:flex;flex-direction:column;gap:.15rem}.brand-publicidad{font-family:Archivo,sans-serif;color:var(--brand-cyan);font-size:clamp(2.1rem,4.5vw,3.4rem);font-weight:700;letter-spacing:-.025em}.brand-tagline{font-family:Urbanist,sans-serif;color:var(--brand-cyan-dark);letter-spacing:.48em;font-size:.78rem;font-weight:700}.brand-description{max-width:48ch;margin-top:.8rem;color:var(--ink-soft);font-family:Urbanist,sans-serif;font-size:1.05rem;line-height:1.56}.brand-features{margin-top:.6rem;display:grid;gap:.7rem}.brand-feature-item{display:flex;align-items:center;gap:.62rem;color:var(--brand-navy);font-family:Urbanist,sans-serif;font-weight:600}.brand-feature-item:before{content:"";width:10px;height:10px;border-radius:999px;background:linear-gradient(135deg,var(--brand-cyan),var(--brand-cyan-dark));box-shadow:0 0 0 4px #35c9c433}.login-card{display:flex;flex-direction:column;justify-content:center;background:#ffffffe6;padding:clamp(1.7rem,3vw,2.4rem);border-left:1px solid rgb(11 47 73 / .08);animation:loginEnter .74s cubic-bezier(.2,.7,.2,1) 80ms both}.login-header{margin-bottom:1.7rem}.login-header h1{font-family:Archivo,sans-serif;font-size:clamp(1.7rem,2.4vw,2rem);font-weight:700;color:var(--brand-navy);margin-bottom:.35rem;letter-spacing:-.02em}.login-header p{color:var(--ink-soft);font-family:Urbanist,sans-serif;font-size:.97rem}.login-card .alert{margin-bottom:1.1rem;font-family:Urbanist,sans-serif;font-size:.93rem}.login-form{display:grid;gap:1.05rem}.form-group{display:grid;gap:.45rem}.form-group label{font-family:Urbanist,sans-serif;font-size:.85rem;font-weight:700;color:var(--brand-navy)}.login-input{height:46px;border-radius:12px;border:1px solid rgb(11 47 73 / .15);background:var(--surface);font-family:Urbanist,sans-serif;font-size:.95rem;transition:border-color .22s ease,box-shadow .22s ease,transform .16s ease}.login-input:focus{border-color:var(--brand-cyan-dark);box-shadow:0 0 0 4px #35c9c433;transform:translateY(-1px)}.login-submit-btn{margin-top:.35rem;width:100%;height:46px;border:none;border-radius:12px;color:#fff;font-family:Archivo,sans-serif;font-size:.95rem;font-weight:700;letter-spacing:.01em;background:linear-gradient(135deg,var(--brand-cyan),var(--brand-cyan-dark));cursor:pointer;transition:transform .16s ease,box-shadow .18s ease,filter .18s ease;box-shadow:0 13px 26px #20b4af47}.login-submit-btn:hover:not(:disabled){transform:translateY(-2px);filter:saturate(1.08);box-shadow:0 16px 26px #20b4af57}.login-submit-btn:active:not(:disabled){transform:translateY(0)}.login-submit-btn:disabled{opacity:.75;cursor:not-allowed}.login-footer{margin-top:1.4rem;text-align:center;color:#6d7f8b;font-family:Urbanist,sans-serif;font-size:.82rem}@media (max-width: 960px){.login-page{padding:1.25rem}.login-container{grid-template-columns:1fr;max-width:540px}.login-brand-panel{padding-bottom:1.3rem;border-bottom:1px solid rgb(11 47 73 / .08)}.brand-tagline{letter-spacing:.26em}.login-card{border-left:none}}@media (max-width: 520px){.login-page{padding:.7rem}.login-container{border-radius:20px}.login-brand-panel,.login-card{padding:1.2rem}.brand-logo{flex-direction:column;align-items:flex-start;gap:.3rem}.brand-hi:after{display:none}.brand-tagline{letter-spacing:.2em;font-size:.72rem}.brand-description{font-size:.95rem}}@keyframes loginEnter{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes loginDrift{0%,to{transform:translateZ(0) scale(1)}50%{transform:translate3d(0,20px,0) scale(1.05)}}.navbar{position:sticky;top:0;z-index:120;border-bottom:1px solid rgb(255 255 255 / .9);box-shadow:0 14px 22px #0d304b17;background:linear-gradient(145deg,#fffffff2,#f6fbffeb);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.navbar-container{max-width:1320px;margin:0 auto;padding:.8rem 1.2rem;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.85rem}.navbar-brand-group{display:flex;align-items:center;gap:.55rem;min-width:0}.navbar-brand{border:none;background:transparent;display:inline-flex;align-items:baseline;gap:.24rem;cursor:pointer;padding:0}.brand-mark{font-family:Archivo,sans-serif;font-weight:800;color:#0d304b;font-size:1.62rem;letter-spacing:-.04em}.brand-name{font-family:Archivo,sans-serif;font-weight:700;color:#2ec7c2;font-size:1.62rem;letter-spacing:-.03em}.user-badge{background:#0d304b14;color:#2f4f64;border-radius:999px;padding:.3rem .72rem;font-family:Urbanist,sans-serif;font-size:.78rem;font-weight:700;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;max-width:220px}.navbar-menu{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.35rem}.nav-link{border:none;border-radius:10px;min-height:35px;padding:.48rem .75rem;font-family:Urbanist,sans-serif;font-size:.82rem;font-weight:700;color:#28475d;background:transparent;cursor:pointer;transition:color .2s ease,background-color .2s ease,transform .15s ease}.nav-link:hover{color:#0d304b;background:#0d304b17;transform:translateY(-1px)}.nav-link.active{color:#fff;background:linear-gradient(135deg,#2ec7c2,#16aca7);box-shadow:0 8px 16px #16aca74d}.navbar-actions{display:flex;justify-content:flex-end}.nav-logout-btn{border:none;border-radius:10px;min-height:38px;padding:.58rem .95rem;font-family:Urbanist,sans-serif;font-size:.82rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#5a6f7f,#476171);cursor:pointer;transition:transform .15s ease,filter .2s ease,box-shadow .2s ease}.nav-logout-btn:hover{transform:translateY(-1px);filter:saturate(1.05);box-shadow:0 10px 18px #4761714d}@media (max-width: 1200px){.navbar-container{grid-template-columns:1fr}.navbar-brand-group{justify-content:center;width:100%}.navbar-menu,.navbar-actions{justify-content:center}}@media (max-width: 760px){.navbar-container{padding:.65rem .7rem;gap:.6rem}.navbar-brand-group{flex-direction:column;gap:.38rem}.brand-mark,.brand-name{font-size:1.34rem}.user-badge{max-width:88vw}.navbar-menu{width:100%;justify-content:flex-start;flex-wrap:nowrap;overflow-x:auto;padding-bottom:.2rem;scrollbar-width:thin}.navbar-menu::-webkit-scrollbar{height:6px}.navbar-menu::-webkit-scrollbar-thumb{background:#0d304b33;border-radius:999px}.nav-link{white-space:nowrap}.navbar-actions,.nav-logout-btn{width:100%}}.dashboard-page{--dash-cyan: #2ec7c2;--dash-cyan-deep: #16aca7;--dash-navy: #0d304b;--dash-ink-soft: #526b7c;--dash-surface: #f5fbfd;min-height:100vh;background:radial-gradient(920px 560px at 3% 12%,rgb(46 199 194 / .13),transparent 64%),radial-gradient(900px 540px at 97% 88%,rgb(13 48 75 / .1),transparent 62%),linear-gradient(180deg,#f6fbff,#eef5fa 58%,#e8f0f8)}.dashboard-shell{max-width:1320px;margin:0 auto;padding:2rem 1.4rem 2.4rem;display:grid;gap:1.2rem}.dashboard-hero{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(300px,.95fr);gap:1.1rem}.hero-content,.hero-summary{border-radius:22px;border:1px solid rgb(255 255 255 / .95);box-shadow:0 22px 38px #112e4817}.hero-content{padding:clamp(1.3rem,2.8vw,2rem);background:linear-gradient(145deg,#ffffffdb,#ffffffad),linear-gradient(125deg,#2ec7c224,#2ec7c20a);animation:dashFadeUp .46s ease both}.hero-eyebrow{display:inline-flex;margin-bottom:.85rem;padding:.34rem .75rem;border-radius:999px;background:#0d304b14;color:var(--dash-navy);font-family:Urbanist,sans-serif;letter-spacing:.09em;text-transform:uppercase;font-size:.73rem;font-weight:700}.hero-content h1{margin:0 0 .7rem;font-family:Archivo,sans-serif;font-weight:800;font-size:clamp(1.65rem,2.8vw,2.35rem);line-height:1.15;color:var(--dash-navy);letter-spacing:-.02em}.hero-description{margin:0;max-width:62ch;font-family:Urbanist,sans-serif;color:var(--dash-ink-soft);font-size:1rem;line-height:1.56}.hero-pills{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1rem}.hero-pill{border-radius:999px;padding:.34rem .82rem;background:linear-gradient(135deg,var(--dash-cyan),var(--dash-cyan-deep));color:#fff;font-family:Urbanist,sans-serif;font-size:.8rem;font-weight:700}.hero-pill-soft{background:#0d304b17;color:var(--dash-navy);font-weight:600}.hero-cta-row{margin-top:1.2rem;display:flex;flex-wrap:wrap;gap:.68rem}.dash-btn{border:none;border-radius:11px;min-height:40px;padding:.62rem 1rem;font-family:Urbanist,sans-serif;font-size:.88rem;font-weight:700;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,background-color .2s ease}.dash-btn-primary{color:#fff;background:linear-gradient(135deg,var(--dash-cyan),var(--dash-cyan-deep));box-shadow:0 12px 22px #16aca747}.dash-btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 16px 24px #16aca757}.dash-btn-ghost{background:#0d304b14;color:var(--dash-navy)}.dash-btn-ghost:hover:not(:disabled){transform:translateY(-1px);background:#0d304b21}.dash-btn:disabled{opacity:.7;cursor:not-allowed;transform:none;box-shadow:none}.hero-summary{padding:1.2rem 1.2rem 1.1rem;background:linear-gradient(145deg,#0d304bf5,#134162eb);color:#fff;display:grid;align-content:start;gap:.8rem;animation:dashFadeUp .56s ease 60ms both}.hero-summary h2{margin:0;font-family:Archivo,sans-serif;font-size:1.2rem;font-weight:700}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:.95rem}.action-card{padding:1rem;border-radius:18px;border:1px solid rgb(255 255 255 / .95);background:#ffffffd6;box-shadow:0 18px 30px #112e4814;display:grid;gap:.74rem;min-height:220px;transition:transform .18s ease,box-shadow .22s ease;animation:dashFadeUp .52s ease both}.action-card:hover{transform:translateY(-3px);box-shadow:0 22px 32px #112e4821}.action-card-head{display:flex;justify-content:space-between;align-items:center;gap:.6rem}.action-icon{width:2rem;height:2rem;border-radius:11px;display:grid;place-items:center;font-size:1.08rem;font-weight:700;font-family:Archivo,sans-serif;color:var(--dash-navy);background:#0d304b14}.action-tag{padding:.27rem .58rem;border-radius:999px;font-family:Urbanist,sans-serif;font-size:.68rem;letter-spacing:.04em;text-transform:uppercase;font-weight:700;color:#0d304bd1;background:#0d304b17}.action-card h3{margin:0;font-family:Archivo,sans-serif;font-size:1.06rem;line-height:1.3;color:var(--dash-navy)}.action-card p{margin:0;color:var(--dash-ink-soft);font-family:Urbanist,sans-serif;font-size:.91rem;line-height:1.5}.action-card .dash-btn{margin-top:auto}.action-card.teal{background:linear-gradient(170deg,#e5faf8,#ffffffeb)}.action-card.blue{background:linear-gradient(170deg,#eaf5ff,#ffffffeb)}.action-card.navy{background:linear-gradient(170deg,#e7f0f9,#ffffffeb)}.action-card.violet{background:linear-gradient(170deg,#f2eeff,#ffffffeb)}.action-card.teal-soft{background:linear-gradient(170deg,#eefdfb,#ffffffeb)}.action-card.muted{background:linear-gradient(170deg,#f1f4f7,#ffffffe6)}.action-card.is-disabled{opacity:.85}.action-card.is-disabled .dash-btn-primary{background:#95a7b4}.system-panel{border-radius:20px;border:1px solid rgb(255 255 255 / .94);background:#ffffffdb;box-shadow:0 18px 30px #112e4814;padding:1.15rem;animation:dashFadeUp .62s ease 80ms both}.system-panel h2{margin:0 0 .9rem;font-family:Archivo,sans-serif;font-size:1.2rem;color:var(--dash-navy)}.system-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:.7rem}.system-item{border-radius:12px;border:1px solid rgb(13 48 75 / .1);padding:.82rem;background:var(--dash-surface);display:grid;gap:.18rem}.system-item span{font-family:Urbanist,sans-serif;font-size:.77rem;text-transform:uppercase;letter-spacing:.06em;color:var(--dash-ink-soft)}.system-item strong{font-family:Archivo,sans-serif;font-weight:600;color:var(--dash-navy);font-size:.98rem;word-break:break-word}@media (max-width: 1060px){.dashboard-hero{grid-template-columns:1fr}.hero-summary{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));align-items:stretch}.hero-summary h2{grid-column:1 / -1}}@media (max-width: 720px){.dashboard-shell{padding:1rem .75rem 1.3rem}.dashboard-grid{grid-template-columns:1fr}.hero-pill-soft{max-width:100%;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.hero-cta-row{display:grid;grid-template-columns:1fr}.dash-btn{width:100%}}@keyframes dashFadeUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.stats-page{--stats-cyan: #2ec7c2;--stats-cyan-deep: #16aca7;--stats-navy: #0d304b;--stats-ink-soft: #526b7c;--stats-surface: #f5fbfd;min-height:100vh;background:radial-gradient(920px 560px at 3% 12%,rgb(46 199 194 / .13),transparent 64%),radial-gradient(900px 540px at 97% 88%,rgb(13 48 75 / .1),transparent 62%),linear-gradient(180deg,#f6fbff,#eef5fa 58%,#e8f0f8)}.stats-shell{max-width:1320px;margin:0 auto;padding:2rem 1.4rem 2.4rem;display:grid;gap:1.15rem}.stats-hero{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(300px,.95fr);gap:1.1rem}.stats-hero-content,.stats-hero-summary{border-radius:22px;border:1px solid rgb(255 255 255 / .95);box-shadow:0 22px 38px #112e4817}.stats-hero-content{padding:clamp(1.3rem,2.8vw,2rem);background:linear-gradient(145deg,#ffffffdb,#ffffffad),linear-gradient(125deg,#2ec7c224,#2ec7c20a);animation:statsFadeUp .46s ease both}.stats-eyebrow{display:inline-flex;margin-bottom:.85rem;padding:.34rem .75rem;border-radius:999px;background:#0d304b14;color:var(--stats-navy);font-family:Urbanist,sans-serif;letter-spacing:.09em;text-transform:uppercase;font-size:.73rem;font-weight:700}.stats-hero-content h1{margin:0 0 .7rem;font-family:Archivo,sans-serif;font-weight:800;font-size:clamp(1.65rem,2.8vw,2.35rem);line-height:1.15;color:var(--stats-navy);letter-spacing:-.02em}.stats-hero-description{margin:0;max-width:68ch;font-family:Urbanist,sans-serif;color:var(--stats-ink-soft);font-size:1rem;line-height:1.56}.stats-hero-pills{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1rem}.stats-pill{border-radius:999px;padding:.34rem .82rem;background:linear-gradient(135deg,var(--stats-cyan),var(--stats-cyan-deep));color:#fff;font-family:Urbanist,sans-serif;font-size:.8rem;font-weight:700}.stats-pill-soft{background:#0d304b17;color:var(--stats-navy);font-weight:600}.stats-hero-summary{padding:1.2rem 1.2rem 1.1rem;background:linear-gradient(145deg,#0d304bf5,#134162eb);color:#fff;display:grid;align-content:start;gap:.8rem;animation:statsFadeUp .56s ease 60ms both}.stats-hero-summary h2{margin:0;font-family:Archivo,sans-serif;font-size:1.2rem;font-weight:700}.stats-summary-item{padding:.82rem;border-radius:12px;border:1px solid rgb(255 255 255 / .16);background:#ffffff14;display:flex;align-items:center;justify-content:space-between;gap:.7rem;font-family:Urbanist,sans-serif}.stats-summary-label{font-size:.82rem;color:#f0f9ffcc}.stats-summary-item strong{font-size:.95rem}.stats-loading-panel,.stats-error-panel{border-radius:20px;border:1px solid rgb(255 255 255 / .94);background:#ffffffdb;box-shadow:0 18px 30px #112e4814;padding:1.2rem;font-family:Urbanist,sans-serif}.stats-loading-panel{color:#5f7687}.stats-error-panel{color:#a21d34;border-left:4px solid #e11d48}.stats-kpis-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.85rem}.stats-kpi-card{border-radius:16px;border:1px solid rgb(255 255 255 / .95);box-shadow:0 18px 30px #112e4814;padding:.95rem;display:grid;gap:.35rem;animation:statsFadeUp .5s ease both}.stats-kpi-card h3{margin:0;font-family:Urbanist,sans-serif;font-size:.76rem;color:#4f6577;text-transform:uppercase;letter-spacing:.08em}.stats-kpi-value{font-family:Archivo,sans-serif;font-size:1.58rem;line-height:1.1;color:var(--stats-navy)}.stats-kpi-card p{margin:0;font-family:Urbanist,sans-serif;font-size:.82rem;color:#62798a}.stats-kpi-card.cyan{background:linear-gradient(170deg,#e6faf8,#fffffff0)}.stats-kpi-card.blue{background:linear-gradient(170deg,#e9f5ff,#fffffff0)}.stats-kpi-card.navy{background:linear-gradient(170deg,#e7f0f9,#fffffff0)}.stats-kpi-card.violet{background:linear-gradient(170deg,#f2eeff,#fffffff0)}.stats-overview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.85rem}.stats-overview-card{border-radius:16px;border:1px solid rgb(255 255 255 / .95);background:#ffffffdb;box-shadow:0 18px 30px #112e4814;padding:.95rem;animation:statsFadeUp .54s ease both}.stats-overview-card h3{margin:0 0 .5rem;font-family:Urbanist,sans-serif;font-size:.78rem;color:#5a7283;text-transform:uppercase;letter-spacing:.08em}.stats-overview-card p{margin:0;font-family:Archivo,sans-serif;color:var(--stats-navy);font-size:1.33rem}.stats-charts-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem}.stats-chart-card{border-radius:18px;border:1px solid rgb(255 255 255 / .95);background:#ffffffe6;box-shadow:0 18px 30px #112e4814;padding:.95rem;min-height:370px;animation:statsFadeUp .6s ease both}.stats-chart-card.wide{grid-column:span 2}.stats-chart-head{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;margin-bottom:.75rem}.stats-chart-head h3{margin:0;font-family:Archivo,sans-serif;font-size:1.01rem;color:var(--stats-navy)}.stats-chart-head span{border-radius:999px;padding:.25rem .62rem;font-family:Urbanist,sans-serif;font-size:.7rem;font-weight:700;color:#345267;background:#0d304b14}.stats-table-card{border-radius:18px;border:1px solid rgb(255 255 255 / .95);background:#ffffffe6;box-shadow:0 18px 30px #112e4814;padding:.95rem;animation:statsFadeUp .62s ease both}.stats-table-wrap{overflow-x:auto;border-radius:12px;border:1px solid rgb(13 48 75 / .08)}.stats-table{width:100%;border-collapse:collapse}.stats-table th,.stats-table td{padding:.72rem;border-bottom:1px solid rgb(13 48 75 / .09);font-family:Urbanist,sans-serif;font-size:.84rem;text-align:left}.stats-table th{background:#f2f8fd;color:var(--stats-navy);font-weight:700}.stats-table td{color:#3a5568}.stats-table tbody tr:hover{background:#f6fcff}.stats-page .recharts-cartesian-axis-tick{fill:#5a7283;font-size:11px}.stats-page .recharts-legend-item-text{color:#466176!important;font-family:Urbanist,sans-serif;font-size:12px}@media (max-width: 1160px){.stats-hero{grid-template-columns:1fr}.stats-hero-summary{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));align-items:stretch}.stats-hero-summary h2{grid-column:1 / -1}.stats-chart-card.wide{grid-column:span 1}}@media (max-width: 900px){.stats-charts-grid{grid-template-columns:1fr}}@media (max-width: 760px){.stats-shell{padding:1rem .75rem 1.3rem}.stats-hero-pills,.stats-chart-head{flex-direction:column;align-items:flex-start}.stats-kpis-grid,.stats-overview-grid{grid-template-columns:1fr}}@keyframes statsFadeUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.calculadora-page{--calc-cyan: #2ec7c2;--calc-cyan-deep: #16aca7;--calc-navy: #0d304b;--calc-ink-soft: #526b7c;--calc-surface: #f5fbfd;min-height:100vh;background:radial-gradient(920px 560px at 3% 12%,rgb(46 199 194 / .13),transparent 64%),radial-gradient(900px 540px at 97% 88%,rgb(13 48 75 / .1),transparent 62%),linear-gradient(180deg,#f6fbff,#eef5fa 58%,#e8f0f8)}.calculadora-container{max-width:1320px;margin:0 auto;padding:2rem 1.4rem 2.4rem;display:grid;gap:1.15rem}.calculadora-hero{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(300px,.95fr);gap:1.1rem}.calculadora-hero-content,.calculadora-hero-summary{border-radius:22px;border:1px solid rgb(255 255 255 / .95);box-shadow:0 22px 38px #112e4817}.calculadora-hero-content{padding:clamp(1.3rem,2.8vw,2rem);background:linear-gradient(145deg,#ffffffdb,#ffffffad),linear-gradient(125deg,#2ec7c224,#2ec7c20a);animation:calcFadeUp .46s ease both}.calculadora-eyebrow{display:inline-flex;margin-bottom:.85rem;padding:.34rem .75rem;border-radius:999px;background:#0d304b14;color:var(--calc-navy);font-family:Urbanist,sans-serif;letter-spacing:.09em;text-transform:uppercase;font-size:.73rem;font-weight:700}.calculadora-hero-content h1{margin:0 0 .7rem;font-family:Archivo,sans-serif;font-weight:800;font-size:clamp(1.65rem,2.8vw,2.35rem);line-height:1.15;color:var(--calc-navy);letter-spacing:-.02em}.calculadora-hero-description{margin:0;max-width:68ch;font-family:Urbanist,sans-serif;color:var(--calc-ink-soft);font-size:1rem;line-height:1.56}.calculadora-header-meta{margin-top:.95rem;display:flex;align-items:center;flex-wrap:wrap;gap:.6rem;font-family:Urbanist,sans-serif;color:#2f4f64;font-size:.86rem}.calculadora-header-meta strong{color:var(--calc-navy)}.calculadora-header-meta.muted{color:#6e8494}.change-category-btn{border:none;border-radius:999px;min-height:30px;padding:.32rem .72rem;font-family:Urbanist,sans-serif;font-size:.78rem;font-weight:700;cursor:pointer;color:#fff;background:linear-gradient(135deg,var(--calc-cyan),var(--calc-cyan-deep));transition:transform .15s ease,box-shadow .2s ease}.change-category-btn:hover{transform:translateY(-1px);box-shadow:0 8px 16px #16aca73d}.calculadora-hero-summary{padding:1.2rem 1.2rem 1.1rem;background:linear-gradient(145deg,#0d304bf5,#134162eb);color:#fff;display:grid;align-content:start;gap:.8rem;animation:calcFadeUp .56s ease 60ms both}.calculadora-hero-summary h2{margin:0;font-family:Archivo,sans-serif;font-size:1.2rem;font-weight:700}.calculadora-summary-item{padding:.82rem;border-radius:12px;border:1px solid rgb(255 255 255 / .16);background:#ffffff14;display:flex;align-items:center;justify-content:space-between;gap:.7rem;font-family:Urbanist,sans-serif}.calculadora-summary-label{font-size:.82rem;color:#f0f9ffcc}.calculadora-summary-item strong{font-size:.95rem}.action-buttons{display:flex;justify-content:flex-end;gap:.65rem;flex-wrap:wrap}.calculadora-page .btn{border-radius:11px;min-height:40px;padding:.62rem 1rem;font-family:Urbanist,sans-serif;font-size:.88rem;font-weight:700;transition:transform .15s ease,box-shadow .2s ease,filter .2s ease}.calculadora-page .btn:hover:not(:disabled){transform:translateY(-1px);filter:saturate(1.06)}.calculadora-page .btn.btn-primary{background:linear-gradient(135deg,#2a67d4,#2457b4);box-shadow:0 11px 22px #2457b43d}.calculadora-page .btn.btn-success{background:linear-gradient(135deg,var(--calc-cyan),var(--calc-cyan-deep));box-shadow:0 11px 22px #16aca73d}.calculadora-page .btn.btn-danger{background:linear-gradient(135deg,#e84c5e,#cc3143);box-shadow:0 11px 22px #cc314333}.calculadora-page .btn.btn-secondary{background:linear-gradient(135deg,#6d8290,#516b7a);box-shadow:0 11px 22px #516b7a33}.calculadora-page .btn.btn-info{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 11px 22px #2563eb3d}.calculadora-page .btn:disabled{opacity:.7;cursor:not-allowed;transform:none;box-shadow:none}.categoria-selector-container{background:#ffffffdb;border-radius:20px;border:1px solid rgb(255 255 255 / .95);box-shadow:0 18px 30px #112e4814;padding:1.5rem;animation:calcFadeUp .52s ease both}.categoria-selector-header{margin-bottom:1.1rem}.categoria-selector-header h2{font-family:Archivo,sans-serif;font-size:1.4rem;line-height:1.2;color:var(--calc-navy);margin-bottom:.35rem}.categoria-selector-header p{color:var(--calc-ink-soft);font-family:Urbanist,sans-serif;font-size:.95rem}.categorias-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.85rem}.categoria-card{border-radius:16px;border:1px solid rgb(13 48 75 / .12);background:linear-gradient(170deg,#fffffff2,#f8fcffeb);padding:1rem;transition:transform .16s ease,box-shadow .22s ease,border-color .2s ease}.categoria-card.activa{cursor:pointer}.categoria-card.activa:hover{transform:translateY(-2px);border-color:#2ec7c2a6;box-shadow:0 18px 30px #2ec7c22e}.categoria-card.deshabilitada{cursor:not-allowed;opacity:.62}.categoria-nombre{font-family:Archivo,sans-serif;font-size:1rem;color:var(--calc-navy);margin-bottom:.9rem;min-height:2.4rem;display:flex;align-items:center}.categoria-estado{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:.28rem .62rem;font-family:Urbanist,sans-serif;font-size:.74rem;font-weight:700}.estado-activa{background:#22c55e29;color:#166534}.estado-proceso{background:#f59e0b33;color:#92400e}.estado-inactiva{background:#ef444429;color:#991b1b}.tabs{display:flex;gap:.5rem;flex-wrap:wrap;padding:1rem;border-radius:18px 18px 0 0;border:1px solid rgb(255 255 255 / .95);border-bottom:none;background:#ffffffdb;box-shadow:0 18px 30px #112e4814}.tab{border:none;border-radius:10px;min-height:38px;padding:.5rem .85rem;background:#0d304b14;color:var(--calc-navy);font-family:Urbanist,sans-serif;font-size:.83rem;font-weight:700;cursor:pointer;transition:transform .15s ease,background-color .2s ease}.tab:hover{transform:translateY(-1px);background:#0d304b21}.tab.active{color:#fff;background:linear-gradient(135deg,var(--calc-cyan),var(--calc-cyan-deep))}.tab-content{background:#ffffffdb;border:1px solid rgb(255 255 255 / .95);border-top:none;border-radius:0 0 18px 18px;box-shadow:0 18px 30px #112e4814;padding:1.15rem;min-height:420px}.tab-panel{animation:calcFadeUp .3s ease}.espesores-guide{margin-bottom:1rem;padding:1rem;border-radius:16px;background:linear-gradient(135deg,#2ec7c217,#3b82f614),#f8fbff;border:1px solid #c9e8e5}.espesores-guide-header{display:flex;justify-content:space-between;align-items:flex-end;gap:.9rem;flex-wrap:wrap;margin-bottom:.85rem}.espesores-guide-kicker{display:inline-block;margin-bottom:.28rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#0f766e;font-family:Urbanist,sans-serif}.espesores-guide-header h3{margin:0;color:var(--calc-navy);font-family:Archivo,sans-serif;font-size:1rem}.espesores-guide-header p{margin:0;max-width:460px;color:#4d6678;font-size:.88rem;line-height:1.45;font-family:Urbanist,sans-serif}.espesores-guide-selection{margin-bottom:.9rem;padding:.72rem .8rem;border-radius:.7rem;background:#ffffffeb;border:1px solid #cbd5e1;color:#334155;font-size:.87rem;font-family:Urbanist,sans-serif}.espesores-guide-selection strong{color:var(--calc-navy)}.espesores-guide-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem}.espesores-card{background:#fff;border:1px solid #e2e8f0;border-radius:.8rem;padding:.9rem;box-shadow:0 8px 22px #0f172a0f;transition:transform .2s ease,box-shadow .2s ease,opacity .2s ease,border-color .2s ease}.espesores-guide.has-active-selection .espesores-card{opacity:.56}.espesores-guide.has-active-selection .espesores-card.is-active{opacity:1;transform:translateY(-2px);border-color:#94a3b8;box-shadow:0 14px 25px #0f172a21}.espesores-card h4{margin:0 0 .68rem;font-family:Archivo,sans-serif;color:var(--calc-navy);font-size:.96rem}.espesores-card-mdf{border-top:4px solid #8b5e3c}.espesores-card-pvc{border-top:4px solid #0284c7}.espesores-card-acrilico{border-top:4px solid #7c3aed}.espesores-card-mdf.is-active{box-shadow:0 16px 24px #8b5e3c2e}.espesores-card-pvc.is-active{box-shadow:0 16px 24px #0284c72e}.espesores-card-acrilico.is-active{box-shadow:0 16px 24px #7c3aed2e}.espesores-list{display:flex;flex-direction:column;gap:.55rem}.espesores-item{padding:.58rem .66rem;border-radius:.64rem;background:#f8fafc;border:1px solid #e2e8f0}.espesores-label{display:block;margin-bottom:.2rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#64748b;font-family:Urbanist,sans-serif}.espesores-item strong{display:block;color:#0f172a;font-family:Urbanist,sans-serif;font-size:.83rem;line-height:1.35}.section-card{border-radius:14px;border:1px solid rgb(13 48 75 / .1);background:var(--calc-surface);padding:1rem;margin-bottom:1rem}.section-card h3{font-family:Archivo,sans-serif;color:var(--calc-navy);font-size:1.02rem;margin-bottom:.78rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;margin-top:.75rem}.calculadora-page .form-group{display:flex;flex-direction:column;gap:.4rem}.calculadora-page .form-group label{display:flex;align-items:center;gap:.75rem;font-family:Urbanist,sans-serif;font-weight:500;font-size:.95rem;color:var(--calc-navy);cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .2s ease}.calculadora-page .form-group label:hover{color:var(--calc-cyan-deep)}.calculadora-page .form-group input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:22px;height:22px;min-width:22px;min-height:22px;border:2px solid var(--calc-cyan);border-radius:6px;background:transparent;cursor:pointer;transition:all .2s ease;position:relative;display:flex;align-items:center;justify-content:center}.calculadora-page .form-group input[type=checkbox]:hover{border-color:var(--calc-cyan-deep);box-shadow:0 0 0 3px #2ec7c226}.calculadora-page .form-group input[type=checkbox]:checked{background:linear-gradient(135deg,var(--calc-cyan) 0%,var(--calc-cyan-deep) 100%);border-color:var(--calc-cyan-deep);box-shadow:0 4px 12px #2ec7c24d}.calculadora-page .form-group input[type=checkbox]:checked:after{content:"✓";color:#fff;font-weight:700;font-size:14px;line-height:1;animation:calcCheckmark .3s cubic-bezier(.34,1.56,.64,1) both}@keyframes calcCheckmark{0%{opacity:0;transform:scale(.5) rotate(-45deg)}to{opacity:1;transform:scale(1) rotate(0)}}.calculadora-page .input,.calculadora-page .select,.calculadora-page textarea.input{border-radius:10px;border:1px solid rgb(13 48 75 / .16);background:#f7fcff;min-height:41px;font-family:Urbanist,sans-serif;font-size:.9rem}.calculadora-page .input:focus,.calculadora-page .select:focus,.calculadora-page textarea.input:focus{outline:none;border-color:var(--calc-cyan-deep);box-shadow:0 0 0 3px #2ec7c22e}.calculadora-page .input.input-range-error{border-color:#dc2626;background:#fff5f5;box-shadow:0 0 0 3px #dc26261f}.range-helper{margin-top:.08rem;font-family:Urbanist,sans-serif;font-size:.76rem;font-weight:600;color:#567184}.range-alert{margin-top:.02rem;font-family:Urbanist,sans-serif;font-size:.76rem;font-weight:700;color:#b91c1c}.espesor-range-card{margin-top:.95rem;margin-bottom:.9rem;border-radius:14px;border:1px solid rgb(13 48 75 / .14);background:linear-gradient(145deg,#ffffffeb,#f0f8fde6);padding:.9rem 1rem;box-shadow:0 8px 18px #112e4814}.espesor-range-card.has-error{border-color:#dc26266b;background:linear-gradient(145deg,#fff7f7,#ffecec)}.espesor-range-title{font-family:Archivo,sans-serif;font-size:.95rem;color:var(--calc-navy);font-weight:700;margin-bottom:.5rem}.espesor-range-tags{display:flex;flex-wrap:wrap;gap:.5rem}.espesor-range-tags span{display:inline-flex;align-items:center;border-radius:999px;border:1px solid rgb(13 48 75 / .18);background:#fffffff0;color:#244b67;padding:.3rem .62rem;font-family:Urbanist,sans-serif;font-size:.76rem;font-weight:700;letter-spacing:.01em}.espesor-range-alert{margin:.62rem 0 0;font-family:Urbanist,sans-serif;font-size:.82rem;font-weight:700;color:#a31717}.logistica-modalidad-summary{margin-bottom:.9rem;padding:.72rem .82rem;border-radius:12px;border:1px solid rgb(13 48 75 / .15);background:linear-gradient(145deg,#fffffff2,#edf7fce6);display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.logistica-modalidad-label{display:block;font-family:Urbanist,sans-serif;font-size:.73rem;font-weight:700;color:#5a7386;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.08rem}.logistica-modalidad-summary strong{font-family:Archivo,sans-serif;color:var(--calc-navy);font-size:1rem}.logistica-address-group{grid-column:span 2}.logistica-estimar-group{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end}.logistica-manual-fallback{margin-top:.55rem;width:100%;border-radius:10px;border:1px dashed rgb(13 48 75 / .22);background:#ffffffd9;padding:.6rem}.logistica-manual-fallback label{font-family:Urbanist,sans-serif;font-size:.78rem;font-weight:700;color:#456175;margin-bottom:.3rem;display:block}.logistica-manual-row{display:flex;gap:.45rem;align-items:center;flex-wrap:wrap}.logistica-manual-row .input{min-width:140px;max-width:180px}.logistica-route-links{display:flex;gap:.6rem;margin-top:.55rem;flex-wrap:wrap}.logistica-route-btn{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:.5rem .9rem;border-radius:10px;border:1px solid transparent;font-family:Urbanist,sans-serif;font-size:.83rem;font-weight:700;letter-spacing:.01em;text-decoration:none;transition:transform .15s ease,box-shadow .15s ease,filter .15s ease}.logistica-route-btn:hover{transform:translateY(-1px);box-shadow:0 8px 16px #061b2c26;filter:brightness(1.02)}.logistica-route-btn:focus-visible{outline:2px solid #0e7bb8;outline-offset:2px}.logistica-route-btn-maps{background:linear-gradient(140deg,#0f9f69,#0b8458);color:#fff}.logistica-route-btn-waze{background:linear-gradient(140deg,#2b6fd1,#1959b6);color:#fff}.modalidad-logistica-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;background:#030d1694;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:grid;place-items:center;padding:1rem}.modalidad-logistica-modal{width:min(760px,100%);border-radius:18px;border:1px solid rgb(255 255 255 / .86);background:linear-gradient(148deg,#fffffff7,#f1f9fff2);box-shadow:0 26px 42px #071c2c45;padding:1.2rem;animation:calcFadeUp .22s ease both}.modalidad-logistica-modal h3{margin:0 0 .34rem;font-family:Archivo,sans-serif;color:var(--calc-navy);font-size:1.26rem}.modalidad-logistica-modal p{margin:0 0 .88rem;font-family:Urbanist,sans-serif;color:#5c7384}.modalidad-logistica-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.68rem}.modalidad-logistica-option{border:1px solid rgb(13 48 75 / .18);background:#fffffff5;border-radius:12px;padding:.8rem .9rem;text-align:left;display:grid;gap:.24rem;cursor:pointer;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.modalidad-logistica-option strong{font-family:Archivo,sans-serif;color:var(--calc-navy);font-size:.98rem}.modalidad-logistica-option span{font-family:Urbanist,sans-serif;color:#647b8d;font-size:.82rem;line-height:1.4}.modalidad-logistica-option:hover{transform:translateY(-1px);border-color:var(--calc-cyan-deep);box-shadow:0 10px 20px #0c39591f}.select-compact,.form-group-compact{max-width:200px}.nav-buttons{display:flex;justify-content:space-between;gap:.65rem;margin-top:1rem}.descripcion-comercial-card{border:1px solid #cfe4ff;background:linear-gradient(180deg,#f7fbff,#ecf4ff)}.descripcion-comercial-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.9rem;margin-bottom:.85rem;flex-wrap:wrap}.descripcion-comercial-head h3{margin:0 0 .28rem}.descripcion-comercial-head p{margin:0;color:#4f6476;font-family:Urbanist,sans-serif;font-size:.88rem;line-height:1.45}.descripcion-comercial-badge{display:inline-flex;align-items:center;padding:.35rem .65rem;border-radius:999px;background:#dbeafe;color:#1d4ed8;font-family:Urbanist,sans-serif;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.descripcion-comercial-textarea{width:100%;min-height:112px;resize:vertical}.descripcion-comercial-actions{display:flex;justify-content:space-between;align-items:center;gap:.8rem;margin-top:.7rem;flex-wrap:wrap}.descripcion-comercial-actions small{color:#627b8b;font-family:Urbanist,sans-serif;line-height:1.45}.resultado-card{margin-top:1.1rem;border-radius:18px;border:1px solid rgb(255 255 255 / .9);background:radial-gradient(1200px 600px at 5% 0%,rgb(46 199 194 / .2),transparent 55%),linear-gradient(145deg,#0c2d46f7,#134263f2);color:#ecf8ff;padding:1.2rem;box-shadow:0 22px 38px #0c2d4638}.resultado-card-catalogo{margin-top:1.5rem}.resultado-card h3{margin-bottom:.9rem;font-family:Archivo,sans-serif;font-size:1.2rem;color:#fff}.resultado-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.65rem;margin-bottom:1rem}.resultado-item{display:flex;justify-content:space-between;align-items:center;gap:.6rem;background:#ffffff1c;border:1px solid rgb(255 255 255 / .16);padding:.65rem .8rem;border-radius:.62rem}.resultado-item span{font-family:Urbanist,sans-serif;font-size:.84rem}.resultado-item strong{font-family:Archivo,sans-serif;font-size:.98rem;color:#fff}.resultado-item-wide{grid-column:1 / -1}.resultado-item-stack{align-items:flex-start;flex-direction:column;gap:.3rem}.resultado-total{background:#ffffffed;border:1px solid rgb(255 255 255 / .95);color:var(--calc-navy);padding:.92rem;border-radius:.7rem}.total-item{display:flex;justify-content:space-between;align-items:center;gap:.6rem}.total-item span{font-family:Archivo,sans-serif;font-size:1rem}.precio-final{font-family:Archivo,sans-serif;font-size:1.7rem;color:#0f9f69}.alert-with-margin{margin-top:1rem}.cotizacion-actions{margin-top:1rem;padding-top:.9rem;border-top:1px dashed rgb(255 255 255 / .25);display:grid;gap:.75rem}.cotizacion-draft-note{margin:0;font-family:Urbanist,sans-serif;font-size:.78rem;color:#e9f5ffd1}.formulario-cliente{margin-bottom:.4rem;padding:.9rem;border-radius:12px;border:1px solid rgb(255 255 255 / .2);background:#ffffff1c}.formulario-cliente h4{margin:0 0 .7rem;color:#fff;font-family:Archivo,sans-serif;font-size:.96rem}.cliente-field{margin-bottom:.58rem}.cliente-field .input,.cliente-field .cliente-textarea{width:100%;background:#f6fbfff5}.cliente-textarea{min-height:78px;resize:vertical}.cliente-form-actions{display:flex;gap:.55rem;flex-wrap:wrap}.cotizacion-confirmed-row{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.cotizacion-confirmed-badge{border-radius:999px;padding:.35rem .75rem;background:#22c55e2e;color:#dcfce7;font-family:Urbanist,sans-serif;font-weight:700;font-size:.78rem}.add-existing-box{margin-top:.9rem;padding:.9rem;border-radius:12px;border:1px solid rgb(255 255 255 / .24);background:#ffffff1f}.add-existing-title{margin:0 0 .62rem;font-family:Archivo,sans-serif;font-size:.93rem;color:#fff}.add-existing-row{display:flex;gap:.55rem;align-items:center;flex-wrap:wrap}.add-existing-select{flex:1;min-width:220px}.add-existing-feedback{margin-top:.52rem;font-family:Urbanist,sans-serif;font-size:.82rem;font-weight:700}.add-existing-feedback.success{color:#86efac}.add-existing-feedback.error{color:#fda4af}.catalogo-section{border-radius:20px;border:1px solid rgb(255 255 255 / .94);background:#ffffffdb;box-shadow:0 18px 30px #112e4814;padding:1.15rem;animation:calcFadeUp .5s ease both}.catalogo-loading{text-align:center;padding:2rem;color:#6b7f8f;font-family:Urbanist,sans-serif;font-size:.95rem}.catalogo-productos-header h3{margin:0 0 .7rem;font-family:Archivo,sans-serif;color:var(--calc-navy);font-size:1rem}.productos-lista{display:flex;flex-wrap:wrap;gap:.48rem;margin-bottom:1rem}.producto-btn{border:none;border-radius:10px;min-height:37px;padding:.5rem .88rem;background:#0d304b14;color:var(--calc-navy);font-family:Urbanist,sans-serif;font-size:.79rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase;cursor:pointer;transition:transform .15s ease,background-color .2s ease}.producto-btn:hover{transform:translateY(-1px);background:#0d304b21}.producto-btn.selected{color:#fff;background:linear-gradient(135deg,var(--calc-cyan),var(--calc-cyan-deep))}.variantes-section{margin-bottom:1rem}.variantes-title{margin:0 0 .6rem;font-family:Archivo,sans-serif;font-size:.95rem;color:var(--calc-navy)}.variantes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.65rem}.variante-card{border:1px solid rgb(13 48 75 / .12);border-radius:12px;padding:.8rem;cursor:pointer;transition:transform .16s ease,box-shadow .2s ease,border-color .2s ease;background:#fff}.variante-card:hover{transform:translateY(-2px);border-color:#2ec7c2b3;box-shadow:0 14px 24px #2ec7c229}.variante-card.selected{border-color:#2ec7c2cc;background:linear-gradient(170deg,#e6faf8,#fffffff2)}.variante-img-wrap{width:100%;height:130px;display:flex;align-items:center;justify-content:center;margin-bottom:.55rem;background:#f0f6fb;border-radius:8px;overflow:hidden}.variante-img{max-width:100%;max-height:130px;object-fit:contain}.variante-desc{font-family:Urbanist,sans-serif;font-size:.82rem;color:#3f5568;margin-bottom:.24rem;font-weight:700}.variante-copy{font-size:.79rem;color:#5f7788;line-height:1.4;margin-bottom:.42rem;white-space:pre-line;font-family:Urbanist,sans-serif}.variante-precio{font-family:Archivo,sans-serif;font-size:1.02rem;color:#1464d2}.variante-card.selected .variante-precio{color:#0b4da8}.unidad-label{font-size:.72rem;color:#6d8292;font-family:Urbanist,sans-serif;font-weight:600}.cantidad-section{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:.7rem;padding:.85rem;border:1px solid rgb(13 48 75 / .1);border-radius:12px;background:#f7fcff}.precio-preview-catalogo{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;font-size:.86rem;color:#354f61;font-family:Urbanist,sans-serif}.catalogo-descripcion-preview{flex-basis:100%;font-size:.82rem;color:#5a7182;line-height:1.45;white-space:pre-line;font-family:Urbanist,sans-serif}.preview-sep{font-size:1rem;color:#8da0ad;font-weight:500}.total-preview{font-size:.93rem;color:#165bc2;font-family:Urbanist,sans-serif}.total-preview strong{font-family:Archivo,sans-serif;font-size:1.18rem}@media (max-width: 1060px){.calculadora-hero{grid-template-columns:1fr}.calculadora-hero-summary{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));align-items:stretch}.calculadora-hero-summary h2{grid-column:1 / -1}.espesores-guide-grid{grid-template-columns:1fr}}@media (max-width: 760px){.calculadora-container{padding:1rem .75rem 1.3rem}.action-buttons{justify-content:stretch}.action-buttons .btn{width:100%}.tabs{padding:.85rem}.tab{width:100%}.form-row{grid-template-columns:1fr}.select-compact,.form-group-compact{max-width:none}.add-existing-row,.descripcion-comercial-head,.descripcion-comercial-actions,.nav-buttons,.cliente-form-actions,.cotizacion-confirmed-row{flex-direction:column;align-items:stretch}.add-existing-select,.add-existing-row .btn,.cliente-form-actions .btn,.cotizacion-confirmed-row .btn,.nav-buttons .btn{width:100%}.variantes-grid,.categorias-grid,.modalidad-logistica-grid{grid-template-columns:1fr}.logistica-address-group{grid-column:span 1}.modalidad-logistica-modal{padding:1rem}.logistica-manual-row .input,.logistica-manual-row .btn{width:100%;max-width:none}.logistica-route-btn{width:100%}}@keyframes calcFadeUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.producto-seleccionado-card{margin:1rem 0 1.5rem;padding:1.2rem;background:#fff;border:1px solid rgb(13 48 75 / .12);border-radius:16px;box-shadow:0 6px 20px #0d304b14}.producto-seleccionado-table{display:flex;flex-direction:column;width:100%}.producto-seleccionado-row{display:grid;grid-template-columns:180px 1fr 120px;gap:2rem;align-items:flex-start}.producto-seleccionado-img-col{width:180px;height:180px;display:flex;align-items:center;justify-content:center;background:#0d304b0a;border:1px solid rgb(13 48 75 / .1);border-radius:12px;overflow:hidden}.producto-seleccionado-img{width:100%;height:100%;object-fit:contain;padding:.5rem}.producto-seleccionado-img-placeholder{font-size:.85rem;color:#526b7c;text-align:center;font-weight:500}.producto-seleccionado-info-col{display:flex;flex-direction:column;gap:.75rem}.producto-info-group{display:flex;gap:.8rem;margin-bottom:.3rem}.producto-info-group label{font-weight:600;color:#0d304b;min-width:90px;font-size:.9rem;font-family:Archivo,sans-serif}.producto-info-group span{color:#0d304bcc;font-size:.9rem;line-height:1.4}.producto-nombre-strong{font-weight:700;color:#0d304b;font-size:.95rem}.producto-descripcion{font-size:.85rem;line-height:1.5;color:#0d304bb3}.producto-seleccionado-actions{display:flex;flex-direction:column;justify-content:flex-start;gap:.5rem}.btn-change-product{padding:.6rem 1rem;font-size:.85rem;white-space:nowrap;border-radius:10px;border:1px solid rgb(13 48 75 / .2);background:#ffffffe6;color:#0d304b;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:Urbanist,sans-serif}.btn-change-product:hover{background:#0d304b14;border-color:#0d304b66;transform:translateY(-1px)}.btn-change-product:active{transform:translateY(0)}@media (max-width: 768px){.producto-seleccionado-row{grid-template-columns:1fr;gap:1rem}.producto-seleccionado-img-col{width:100%;height:200px}.producto-seleccionado-actions{flex-direction:row}.btn-change-product{flex:1;text-align:center}}.historial-page{--hist-cyan: #2ec7c2;--hist-cyan-deep: #16aca7;--hist-navy: #0d304b;--hist-ink-soft: #526b7c;--hist-surface: #f5fbfd;min-height:100vh;background:radial-gradient(920px 560px at 3% 12%,rgb(46 199 194 / .13),transparent 64%),radial-gradient(900px 540px at 97% 88%,rgb(13 48 75 / .1),transparent 62%),linear-gradient(180deg,#f6fbff,#eef5fa 58%,#e8f0f8)}.historial-page>.historial-container{width:100%;max-width:1320px;margin:0 auto!important;padding:2rem 1.4rem 2.4rem;display:grid;gap:1.15rem;background:transparent;border:0;box-shadow:none}.historial-kicker{display:inline-flex;margin-bottom:.65rem;padding:.34rem .75rem;border-radius:999px;background:#0d304b14;color:var(--hist-navy);font-family:Urbanist,sans-serif;letter-spacing:.09em;text-transform:uppercase;font-size:.73rem;font-weight:700}.historial-hero{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(260px,.85fr);gap:1.1rem}.historial-hero-copy,.historial-hero-summary{border-radius:22px;border:1px solid rgb(255 255 255 / .95);box-shadow:0 22px 38px #112e4817}.historial-hero-copy{padding:clamp(1.3rem,2.8vw,2rem);background:linear-gradient(145deg,#ffffffdb,#ffffffad),linear-gradient(125deg,#2ec7c224,#2ec7c20a);animation:historialFadeUp .46s ease both}.historial-hero-copy h1{margin:0;font-family:Archivo,sans-serif;font-weight:800;font-size:clamp(1.65rem,2.8vw,2.35rem);line-height:1.15;color:var(--hist-navy);letter-spacing:-.02em}.historial-hero-copy p{margin:.8rem 0 0;max-width:66ch;font-family:Urbanist,sans-serif;color:var(--hist-ink-soft);font-size:1rem;line-height:1.56}.historial-hero-summary{padding:1.2rem;background:linear-gradient(145deg,#0d304bf5,#134162eb);color:#fff;display:grid;align-content:start;gap:.75rem;animation:historialFadeUp .56s ease 60ms both}.historial-summary-item{border-radius:12px;border:1px solid rgb(255 255 255 / .16);background:#ffffff14;padding:.78rem;display:flex;justify-content:space-between;align-items:center;gap:.65rem;font-family:Urbanist,sans-serif}.historial-summary-label{font-size:.8rem;color:#f0f9ffcc}.historial-summary-item strong{font-size:1rem}.historial-refresh-btn{width:100%;min-height:40px;border-radius:11px;font-family:Urbanist,sans-serif;font-size:.88rem;font-weight:700;border:none;cursor:pointer;color:#fff;background:linear-gradient(135deg,var(--hist-cyan),var(--hist-cyan-deep));box-shadow:0 12px 22px #16aca747;transition:transform .15s ease,box-shadow .2s ease}.historial-refresh-btn:hover{transform:translateY(-1px);box-shadow:0 15px 24px #16aca757}.historial-overview{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.85rem}.historial-overview-card{background:#ffffffe0;border:1px solid rgb(255 255 255 / .94);border-radius:18px;padding:.95rem;box-shadow:0 18px 30px #112e4814;display:grid;gap:.35rem;animation:historialFadeUp .52s ease both}.historial-overview-card span{font-family:Urbanist,sans-serif;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:#61798a;font-weight:700}.historial-overview-card strong{font-family:Archivo,sans-serif;color:var(--hist-navy);font-size:1.52rem;line-height:1.1}.historial-overview-card small{font-family:Urbanist,sans-serif;font-size:.8rem;color:#6b8190;line-height:1.42}.historial-overview-card-accent{background:linear-gradient(145deg,#0d304bf5,#134162eb)}.historial-overview-card-accent span,.historial-overview-card-accent strong,.historial-overview-card-accent small{color:#f8fbff}.filtros-panel{padding:1rem;border-radius:20px;border:1px solid rgb(255 255 255 / .94);background:#ffffffdb;box-shadow:0 18px 30px #112e4814;animation:historialFadeUp .56s ease both}.filtros-head{display:flex;justify-content:space-between;align-items:flex-end;gap:.75rem;margin-bottom:.85rem}.filtros-head h2{margin:0;font-family:Archivo,sans-serif;font-size:1.2rem;color:var(--hist-navy)}.filtros-count{border-radius:999px;padding:.28rem .64rem;background:#0d304b14;font-family:Urbanist,sans-serif;font-size:.74rem;font-weight:700;color:#314f63}.filtros{display:flex;flex-wrap:wrap;gap:.5rem}.filtro-btn{border:none;border-radius:999px;min-height:36px;padding:.45rem .82rem;background:#0d304b14;color:var(--hist-navy);font-family:Urbanist,sans-serif;font-size:.8rem;font-weight:700;cursor:pointer;transition:transform .15s ease,background-color .2s ease}.filtro-btn:hover{transform:translateY(-1px);background:#0d304b21}.filtro-btn.active{color:#fff;background:linear-gradient(135deg,var(--hist-cyan),var(--hist-cyan-deep));box-shadow:0 10px 18px #16aca747}.empty-state{border-radius:20px;border:1px solid rgb(255 255 255 / .94);background:#ffffffe0;box-shadow:0 18px 30px #112e4814;padding:2rem 1rem;text-align:center;animation:historialFadeUp .6s ease both}.empty-state p{margin:0;font-family:Urbanist,sans-serif;font-size:1rem;color:#647c8b}.empty-state-btn{margin-top:.9rem;border-radius:11px;min-height:38px;padding:.55rem .95rem;font-family:Urbanist,sans-serif;font-size:.84rem;font-weight:700}.table-container{border-radius:22px;border:1px solid rgb(255 255 255 / .94);background:#ffffffe6;box-shadow:0 18px 30px #112e4814;overflow:hidden;animation:historialFadeUp .62s ease both}.table-topbar{display:flex;justify-content:space-between;align-items:flex-end;gap:.75rem;padding:1rem;border-bottom:1px solid rgb(13 48 75 / .1)}.table-topbar h2{margin:0;font-family:Archivo,sans-serif;font-size:1.2rem;color:var(--hist-navy)}.table-topbar p{margin:0;color:#667d8c;font-family:Urbanist,sans-serif;font-size:.82rem;max-width:340px;line-height:1.45;text-align:right}.cotizaciones-table{width:100%;border-collapse:collapse}.cotizaciones-table thead{background:#f2f8fd}.cotizaciones-table th{padding:.8rem .95rem;text-align:left;font-family:Urbanist,sans-serif;font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:var(--hist-navy)}.cotizaciones-table tbody tr{border-bottom:1px solid rgb(13 48 75 / .08);transition:background-color .2s ease}.cotizaciones-table tbody tr:hover{background:#f6fcff}.cotizaciones-table td{padding:.86rem .95rem;font-family:Urbanist,sans-serif;color:#304a5d;font-size:.87rem}.cotizaciones-table tr.estado-borrador{border-left:4px solid #f59e0b}.cotizaciones-table tr.estado-presupuestada{border-left:4px solid #2a67d4}.cotizaciones-table tr.estado-aprobada{border-left:4px solid #16a34a}.cotizaciones-table tr.estado-rechazada{border-left:4px solid #ef4444}.cotizaciones-table tr.estado-cancelada{border-left:4px solid #6b7280;opacity:.78}.badge{display:inline-flex;align-items:center;border-radius:999px;padding:.26rem .62rem;font-family:Urbanist,sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase}.badge-warning{background:#f59e0b29;color:#92400e}.badge-info{background:#2a67d426;color:#1e40af}.badge-success{background:#22c55e29;color:#166534}.badge-danger{background:#ef444429;color:#991b1b}.badge-secondary{background:#64748b29;color:#334155}.precio-final{font-family:Archivo,sans-serif;font-size:1rem;color:#0f9f69}.acciones{display:flex;gap:.45rem}.btn-accion{width:32px;height:32px;border:none;border-radius:9px;cursor:pointer;font-size:14px;display:grid;place-items:center;transition:transform .15s ease,filter .2s ease}.btn-accion:hover{transform:translateY(-1px);filter:saturate(1.05)}.btn-ver{background:#e5f1ff;color:#1d4ed8}.btn-descargar{background:#e7f8ef;color:#15803d}.btn-eliminar{background:#ffe8ed;color:#b91c1c}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0b182485;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}.modal-content{background:#fff;border-radius:22px;box-shadow:0 24px 60px #0b182447;max-width:920px;width:100%;max-height:90vh;overflow-y:auto;border:1px solid rgb(255 255 255 / .9);animation:slideUp .28s ease}.modal-content.small{max-width:430px;padding:1.1rem}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.1rem;border-bottom:1px solid rgb(13 48 75 / .1);background:linear-gradient(145deg,#0d304bf5,#134162eb);color:#fff}.modal-header h2{margin:0;font-family:Archivo,sans-serif;font-size:1.3rem}.historial-modal-header{position:relative;gap:.8rem;align-items:flex-start}.historial-modal-copy{flex:1;min-width:0}.historial-modal-kicker{display:inline-block;margin-bottom:.4rem;font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#ffffffb8;font-family:Urbanist,sans-serif}.historial-modal-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-top:.6rem;font-size:.78rem;color:#ffffffbf;font-family:Urbanist,sans-serif}.historial-modal-totalbox{flex:0 0 190px;padding:.72rem .78rem;border-radius:12px;background:#ffffff1a;border:1px solid rgb(255 255 255 / .14)}.historial-modal-totalbox span{display:block;font-size:.66rem;text-transform:uppercase;letter-spacing:.11em;color:#ffffffbf;font-family:Urbanist,sans-serif}.historial-modal-totalbox strong{display:block;margin-top:.45rem;font-size:1.3rem;color:#ecfdf5;font-family:Archivo,sans-serif}.modal-close{border:none;background:#ffffff1a;color:#fff;width:30px;height:30px;border-radius:8px;cursor:pointer;display:grid;place-items:center;transition:transform .15s ease,background-color .2s ease;flex:0 0 auto}.modal-close:hover{transform:scale(1.06);background:#fff3}.modal-body{padding:1rem 1.1rem}.detalle-section{margin-bottom:.9rem;padding:.86rem;border:1px solid rgb(13 48 75 / .1);border-radius:14px;background:#fff}.detalle-section:last-child{margin-bottom:0}.detalle-section h3{color:var(--hist-navy);margin:0 0 .62rem;font-family:Urbanist,sans-serif;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em}.detalle-section p{margin:0;color:#334155;font-family:Urbanist,sans-serif}.historial-info-grid,.historial-timeline{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem}.historial-info-item,.historial-timeline-item{padding:.72rem;border-radius:12px;background:#f8fbff;border:1px solid #dbe7f2}.historial-info-item span,.historial-timeline-item span{display:block;margin-bottom:.35rem;font-family:Urbanist,sans-serif;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#64748b}.historial-info-item strong,.historial-timeline-item strong{color:#0f172a;font-family:Urbanist,sans-serif;font-size:.86rem;line-height:1.45}.historial-resumen-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem}.historial-resumen-card{background:linear-gradient(180deg,#f8fbff,#fff);border:1px solid #dbe7f2;border-radius:14px;padding:.75rem;display:flex;flex-direction:column;gap:.25rem}.historial-resumen-card span{font-family:Urbanist,sans-serif;font-size:.68rem;color:#667085;text-transform:uppercase;letter-spacing:.06em}.historial-resumen-card strong{color:#1f2937;font-family:Archivo,sans-serif;font-size:.95rem;line-height:1.35}.historial-resumen-card-wide{grid-column:span 2}.historial-total-card{background:linear-gradient(135deg,#eafff6,#d1fae5);border-color:#9be8c8}.historial-total-card strong{color:#0d8f5e;font-size:1.08rem}.historial-items-wrap{overflow-x:auto}.detalle-table{width:100%;border-collapse:collapse}.historial-items-table thead th{text-align:left;font-family:Urbanist,sans-serif;font-size:.69rem;color:#667085;text-transform:uppercase;letter-spacing:.07em;padding:0 0 .45rem;border-bottom:1px solid #dbe7f2}.historial-items-table td{vertical-align:top;padding:.68rem .5rem .68rem 0;border-bottom:1px solid #edf2f7;font-family:Urbanist,sans-serif;font-size:.84rem}.historial-items-table td:first-child{width:26%;color:#111827;font-weight:700}.historial-items-table td:last-child{width:18%;font-family:Archivo,sans-serif;color:#0d8f5e}.historial-item-descripcion{white-space:pre-line;color:#4b5563;line-height:1.45}.historial-empty-detail{color:#667085;margin:0;font-family:Urbanist,sans-serif}.historial-observaciones{padding:.76rem;border-radius:12px;background:#fffaf0;border:1px solid #fde68a;white-space:pre-line;font-family:Urbanist,sans-serif;line-height:1.5}.modal-footer{padding:.95rem 1.1rem 1.1rem;border-top:1px solid rgb(13 48 75 / .1);display:flex;gap:.6rem;justify-content:flex-end;flex-wrap:wrap}.modal-footer .btn{border-radius:10px;min-height:38px;padding:.54rem .9rem;font-family:Urbanist,sans-serif;font-size:.82rem;font-weight:700;border:none;cursor:pointer}.modal-confirm-title{margin:0;color:var(--hist-navy);font-family:Archivo,sans-serif;font-size:1.12rem}.modal-confirm-text{margin:.5rem 0 0;color:#5b7485;font-family:Urbanist,sans-serif;font-size:.9rem;line-height:1.45}.modal-confirm-actions{margin-top:.95rem;padding:0;border-top:none}.spinner{width:48px;height:48px;margin:100px auto;border:4px solid rgb(46 199 194 / .22);border-top-color:var(--hist-cyan-deep);border-radius:50%;animation:spin .9s linear infinite}@media (max-width: 1060px){.historial-hero{grid-template-columns:1fr}.historial-overview{grid-template-columns:repeat(2,minmax(0,1fr))}.historial-info-grid,.historial-timeline,.historial-resumen-grid{grid-template-columns:1fr}.historial-resumen-card-wide{grid-column:span 1}}@media (max-width: 760px){.historial-page>.historial-container{padding:1rem .75rem 1.3rem}.filtros-head,.table-topbar,.historial-modal-header{flex-direction:column;align-items:stretch}.table-topbar p{text-align:left;max-width:none}.cotizaciones-table th,.cotizaciones-table td{padding:.65rem;font-size:.8rem}.acciones{flex-wrap:wrap}.btn-accion{width:30px;height:30px}.modal-content{max-height:92vh}.modal-footer,.modal-confirm-actions{flex-direction:column}.modal-footer .btn,.modal-confirm-actions .btn,.empty-state-btn{width:100%}.historial-modal-totalbox{flex:1 1 auto}}@media (max-width: 560px){.historial-overview{grid-template-columns:1fr}.cotizaciones-table th:nth-child(4),.cotizaciones-table td:nth-child(4),.cotizaciones-table th:nth-child(5),.cotizaciones-table td:nth-child(5){display:none}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes historialFadeUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.modal-content.editor-items-modal{width:min(1100px,96vw);max-width:min(1100px,96vw);max-height:92vh;overflow:hidden;border-radius:12px;display:flex;flex-direction:column}.editor-items-modal .editor-content{padding:20px;display:grid;grid-template-columns:minmax(320px,1fr) minmax(320px,1fr);gap:18px;flex:1;min-height:0;overflow-y:auto;overflow-x:hidden}.editor-items-modal .editor-content.single-pane{grid-template-columns:minmax(0,1fr)}.editor-items-modal .item-form-section{background:#f8f9fa;padding:18px;border-radius:10px;border:1px solid #d9e6ff}.editor-items-modal .item-form-section h3{margin:0 0 14px;color:#0f172a;font-size:16px}.editor-items-modal .item-form{display:flex;flex-direction:column;gap:14px}.editor-items-modal .form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.editor-items-modal .form-group{display:flex;flex-direction:column}.editor-items-modal .form-group label{margin-bottom:6px;font-weight:600;color:#334155;font-size:13px}.editor-items-modal .form-group input,.editor-items-modal .form-group select{padding:10px;border:1px solid #d4d4d8;border-radius:8px;font-size:13px}.editor-items-modal .form-group input:focus,.editor-items-modal .form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f626}.editor-items-modal .form-group input[type=checkbox]{width:16px;height:16px;margin-right:8px}.editor-items-modal .item-form h4{margin:8px 0 0;color:#475569;font-size:13px;border-top:1px solid #e2e8f0;padding-top:10px}.editor-items-modal .calculo-summary{background:#fff;padding:12px;border-radius:8px;border-left:4px solid #16a34a;font-size:13px}.editor-items-modal .calculo-item{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid #e5e7eb}.editor-items-modal .calculo-item:last-child{border-bottom:none}.editor-items-modal .calculo-item.total{background:#ecfdf3;border-radius:6px;margin-top:6px;padding:8px}.editor-items-modal .calculo-item.total strong{color:#16a34a}.editor-items-modal .form-actions{display:flex;gap:10px;margin-top:8px}.editor-items-modal .form-actions button{flex:1}.editor-items-modal .items-list-section{display:flex;flex-direction:column;min-height:0}.editor-items-modal .items-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.editor-items-modal .items-header h3{margin:0;color:#0f172a;font-size:16px}.editor-items-modal .btn-agregar-item{border:none;border-radius:8px;padding:8px 12px;font-size:13px;font-weight:600;color:#fff;background:#2563eb;cursor:pointer}.editor-items-modal .btn-agregar-item:hover{background:#1d4ed8}.editor-items-modal .empty-message{text-align:center;color:#94a3b8;padding:22px 10px;font-size:14px}.editor-items-modal .items-grid{display:grid;gap:12px;overflow:visible;max-height:none;padding-right:8px}.editor-items-modal .item-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.editor-items-modal .item-card:hover{border-color:#93c5fd;box-shadow:0 2px 10px #0f172a14}.editor-items-modal .item-header{background:#f8fafc;padding:10px 12px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #eef2f7}.editor-items-modal .item-number{font-weight:700;color:#0f172a;font-size:13px}.editor-items-modal .item-price{background:#16a34a;color:#fff;border-radius:6px;padding:4px 8px;font-weight:600;font-size:12px}.editor-items-modal .item-content{padding:12px;font-size:12px}.editor-items-modal .item-content p{margin:6px 0;color:#475569}.editor-items-modal .item-content strong{color:#1e293b}.editor-items-modal .badge{display:inline-block;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:700}.editor-items-modal .badge-warning{background:#fff7ed;color:#9a3412}.editor-items-modal .item-costs{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-top:8px;padding:8px}.editor-items-modal .cost-item{display:flex;justify-content:space-between;font-size:11px;padding:4px 0;color:#475569}.editor-items-modal .cost-item span:last-child{font-weight:700;color:#1e293b}.editor-items-modal .item-actions{display:flex;flex-wrap:wrap;gap:6px;padding:10px 12px;background:#f8fafc;border-top:1px solid #eef2f7}.editor-items-modal .item-actions .btn{flex:1;min-width:120px;font-size:11px;padding:6px 8px}.editor-items-modal .item-img-preview{width:100%;text-align:center;margin-bottom:4px}.editor-items-modal .item-img-thumb{max-height:70px;max-width:100%;border-radius:6px;border:1px solid #dbe3ee;object-fit:contain}.editor-items-modal .items-total{margin-top:14px;padding:12px;background:#ecfdf3;border-radius:8px;border-left:4px solid #16a34a}.editor-items-modal .items-total h4{margin:0;color:#15803d;font-size:14px}.editor-items-modal .modal-footer{display:flex;justify-content:space-between;gap:10px;padding:14px 18px;border-top:1px solid #e5e7eb;background:#f8fafc;flex-wrap:wrap}.editor-items-modal .modal-footer .btn{flex:1;min-width:150px}@media (max-width: 1100px){.editor-items-modal .editor-content,.editor-items-modal .editor-content.single-pane{grid-template-columns:1fr}.editor-items-modal .item-form-section{order:2}.editor-items-modal .items-list-section{order:1}}@media (max-width: 768px){.modal-content.editor-items-modal{width:98vw;max-width:98vw;max-height:95vh}.editor-items-modal .editor-content{padding:14px;gap:12px}.editor-items-modal .form-row{grid-template-columns:1fr;gap:10px}.editor-items-modal .item-actions .btn{min-width:100%}}.estados-container{position:relative;display:inline-block}.estado-badge{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:6px;color:#fff;font-weight:600;font-size:14px;cursor:pointer;transition:all .3s ease;border:none;box-shadow:0 2px 4px #0003;-webkit-user-select:none;user-select:none}.estado-badge:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000040}.dropdown-icon{font-size:10px;margin-left:4px}.estado-error{position:absolute;top:100%;left:0;right:0;background:#f8d7da;color:#721c24;padding:10px 12px;border-radius:4px;font-size:12px;margin-top:5px;z-index:100;border:1px solid #f5c6cb}.estados-menu{position:absolute;top:100%;left:0;background:#fff;border:1px solid #ddd;border-radius:6px;margin-top:8px;min-width:200px;box-shadow:0 4px 12px #00000026;z-index:1000;overflow:hidden;animation:slideIn .2s ease}.menu-header{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:#f8f9fa;border-bottom:1px solid #eee;font-weight:600;color:#333;font-size:13px}.menu-close{background:none;border:none;color:#999;cursor:pointer;font-size:16px;padding:0;line-height:1}.menu-close:hover{color:#333}.menu-loading{padding:15px;text-align:center;color:#666;font-size:13px}.menu-items{display:flex;flex-direction:column;max-height:300px;overflow-y:auto}.menu-item{display:flex;align-items:center;gap:10px;background:#fff;border:none;border-left:4px solid var(--hover-color, #007bff);padding:12px 14px;text-align:left;cursor:pointer;transition:all .2s ease;font-size:13px;color:#333;font-weight:500}.menu-item:hover{background:#f8f9fa;padding-left:18px}.menu-item:active{background:#e9ecef}.item-icon{font-size:16px;display:flex;align-items:center;justify-content:center;width:24px}.item-label{flex:1}.menu-empty{padding:15px 14px;text-align:center;color:#999;font-size:12px;margin:0}@media (max-width: 768px){.estado-badge{font-size:12px;padding:8px 12px}.estados-menu{min-width:180px}.menu-item{padding:10px 12px;font-size:12px}.menu-item:hover{padding-left:16px}}.cot-page{--cot-cyan: #2ec7c2;--cot-cyan-deep: #16aca7;--cot-navy: #0d304b;--cot-ink-soft: #546d7e;--cot-bg-card: rgb(255 255 255 / .88);min-height:100vh;background:radial-gradient(940px 560px at 6% 8%,rgb(46 199 194 / .13),transparent 62%),radial-gradient(900px 520px at 95% 92%,rgb(13 48 75 / .11),transparent 62%),linear-gradient(180deg,#f6fbff,#edf4fb 58%,#e8f0f8)}.cot-shell{width:min(1320px,calc(100% - 2rem));margin:0 auto;padding:2rem 0 2.4rem;display:grid;gap:1.15rem}.cot-loading-card,.cot-card{border-radius:22px;border:1px solid rgb(255 255 255 / .95);background:var(--cot-bg-card);box-shadow:0 22px 38px #112e4817}.cot-loading-card{min-height:240px;display:grid;place-items:center;text-align:center;gap:.75rem;font-family:Urbanist,sans-serif;color:var(--cot-ink-soft)}.cot-spinner{width:46px;height:46px;border:4px solid rgb(46 199 194 / .2);border-top-color:var(--cot-cyan-deep);border-radius:50%;animation:cotSpin .9s linear infinite}.cot-hero{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(300px,.95fr);gap:1.1rem}.cot-hero-copy,.cot-hero-summary{border-radius:22px;border:1px solid rgb(255 255 255 / .95);box-shadow:0 22px 38px #112e4817}.cot-hero-copy{padding:clamp(1.3rem,2.8vw,2rem);background:linear-gradient(145deg,#ffffffdb,#ffffffad),linear-gradient(125deg,#2ec7c226,#2ec7c20a);animation:cotFadeUp .42s ease both}.cot-kicker{display:inline-flex;margin-bottom:.82rem;padding:.34rem .75rem;border-radius:999px;background:#0d304b14;color:var(--cot-navy);font-family:Urbanist,sans-serif;letter-spacing:.09em;text-transform:uppercase;font-size:.73rem;font-weight:700}.cot-hero-copy h1{margin:0;font-family:Archivo,sans-serif;font-weight:800;font-size:clamp(1.65rem,2.8vw,2.35rem);line-height:1.15;letter-spacing:-.02em;color:var(--cot-navy)}.cot-hero-copy p{margin:.75rem 0 0;max-width:64ch;font-family:Urbanist,sans-serif;color:var(--cot-ink-soft);font-size:1rem;line-height:1.56}.cot-hero-pills{margin-top:.95rem;display:flex;flex-wrap:wrap;gap:.48rem}.cot-hero-pills span{border-radius:999px;padding:.36rem .72rem;background:#0d304b1a;color:#173a55;font-family:Urbanist,sans-serif;font-size:.78rem;font-weight:700}.cot-hero-summary{padding:1.2rem;background:linear-gradient(145deg,#0d304bf5,#134162eb);color:#fff;display:grid;align-content:start;gap:.72rem;animation:cotFadeUp .52s ease 70ms both}.cot-summary-item{border-radius:12px;border:1px solid rgb(255 255 255 / .16);background:#ffffff14;padding:.82rem;display:grid;gap:.28rem}.cot-summary-item span{font-family:Urbanist,sans-serif;font-size:.78rem;color:#f0f9ffd1}.cot-summary-item strong{font-family:Archivo,sans-serif;font-size:1.12rem;line-height:1.1}.cot-page .btn{border:none;border-radius:11px;min-height:40px;padding:.56rem .92rem;font-family:Urbanist,sans-serif;font-size:.84rem;font-weight:700;cursor:pointer;transition:transform .16s ease,box-shadow .2s ease,filter .2s ease}.cot-page .btn:hover,.cot-page .btn:focus-visible{transform:translateY(-1px)}.cot-create-btn{color:#fff;background:linear-gradient(135deg,var(--cot-cyan),var(--cot-cyan-deep));box-shadow:0 12px 22px #16aca74d}.cot-create-btn.is-open{background:linear-gradient(135deg,#3e6e92,#274b68);box-shadow:0 12px 22px #274b6847}.cot-alert{border-radius:14px;border:1px solid rgb(248 113 113 / .34);background:#fee2e2db;color:#8e2424;padding:.84rem .95rem;font-family:Urbanist,sans-serif;font-size:.88rem;font-weight:600}.cot-card{padding:1rem;animation:cotFadeUp .48s ease both}.cot-card-header h2{margin:0;font-family:Archivo,sans-serif;font-size:1.24rem;color:var(--cot-navy)}.cot-card-header p{margin:.34rem 0 0;color:#668091;font-family:Urbanist,sans-serif;font-size:.86rem}.cot-form{margin-top:.95rem;display:grid;gap:.72rem}.cot-form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.72rem}.cot-field{display:grid;gap:.34rem}.cot-field-sm{max-width:250px}.cot-field label{margin:0;font-family:Urbanist,sans-serif;font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#526d80}.cot-input,.cot-select{width:100%;border-radius:11px;border:1px solid rgb(13 48 75 / .18);background:#fff;padding:.64rem .75rem;font-family:Urbanist,sans-serif;font-size:.87rem;color:#18344a;transition:border-color .2s ease,box-shadow .2s ease}.cot-input:focus,.cot-select:focus{outline:none;border-color:var(--cot-cyan-deep);box-shadow:0 0 0 3px #2ec7c22e}.cot-form-actions{display:flex;justify-content:flex-end;margin-top:.3rem}.cot-submit-btn{background:linear-gradient(135deg,#1fa36b,#0f8a5a);color:#fff;box-shadow:0 12px 22px #0f8a5a3d}.cot-filters-header{display:flex;justify-content:space-between;align-items:flex-end;gap:.8rem}.cot-clear-btn{color:#fff;background:linear-gradient(135deg,#4f6d87,#35506a);box-shadow:0 12px 20px #35506a38}.cot-filters-grid{margin-top:.9rem;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.72rem}.cot-field-wide{grid-column:span 2}.cot-list-header{display:flex;justify-content:space-between;align-items:flex-end;gap:.85rem;margin-bottom:.9rem}.cot-list-header h2{margin:0;font-family:Archivo,sans-serif;font-size:1.22rem;color:var(--cot-navy)}.cot-list-header p{margin:.38rem 0 0;font-family:Urbanist,sans-serif;color:#668091;font-size:.84rem}.cot-list-chip{border-radius:999px;padding:.42rem .82rem;background:#16aca71f;color:#0f5d5a;font-family:Archivo,sans-serif;font-size:.9rem}.cot-empty-state{border-radius:14px;border:1px dashed rgb(13 48 75 / .25);background:#ffffff9e;min-height:130px;display:grid;place-items:center;text-align:center;color:#5f7889;font-family:Urbanist,sans-serif;font-size:.92rem}.cot-table-wrap{overflow-x:auto;border-radius:16px;border:1px solid rgb(13 48 75 / .12)}.cot-table{width:100%;border-collapse:collapse;min-width:980px}.cot-table thead{background:#f2f8fd}.cot-table th{padding:.76rem .84rem;text-align:left;font-family:Urbanist,sans-serif;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--cot-navy)}.cot-table td{padding:.74rem .84rem;border-top:1px solid rgb(13 48 75 / .08);font-family:Urbanist,sans-serif;font-size:.84rem;color:#2f4b5f}.cot-table tbody tr:hover{background:#f8fcff}.cot-id-cell{font-family:Archivo,sans-serif;color:var(--cot-navy)}.cot-user-cell{color:#5a7385}.cot-total-cell{font-family:Archivo,sans-serif;color:#0f8f61}.cot-actions-cell{min-width:240px;display:flex;gap:.35rem;flex-wrap:wrap}.cot-action-btn{min-height:33px;padding:.42rem .64rem;border-radius:9px;box-shadow:none}.cot-action-btn.info{background:#e7f3ff;color:#1e4ca3}.cot-action-btn.edit{background:#e8f8ef;color:#146f3f}.cot-action-btn.danger{background:#ffe9ef;color:#af1f3f}.cot-action-btn.warn{background:#fff4d8;color:#8f6311}.cot-action-btn.ghost{background:#e7edf3;color:#294155}.cot-estado-badge{display:inline-flex;align-items:center;gap:.26rem;border-radius:999px;padding:.28rem .56rem;font-size:.72rem;font-weight:700;letter-spacing:.02em;font-family:Urbanist,sans-serif}.cot-estado-badge.is-borrador,.cot-estado-badge.is-cancelada{background:#6b72802e;color:#374151}.cot-estado-badge.is-presupuestada{background:#3b82f62b;color:#1d4ed8}.cot-estado-badge.is-aprobada{background:#22c55e29;color:#166534}.cot-estado-badge.is-rechazada{background:#ef444429;color:#9b1c1c}.cot-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0a17238f;display:flex;align-items:center;justify-content:center;padding:18px;animation:cotFadeIn .2s ease}.cot-modal{width:min(980px,100%);max-height:92vh;overflow-y:auto;border-radius:22px;border:1px solid rgb(255 255 255 / .92);background:#fff;box-shadow:0 28px 60px #0a172359;animation:cotSlideUp .24s ease}.cot-modal-loading{max-width:420px;min-height:180px;display:grid;place-items:center;gap:.6rem;text-align:center;font-family:Urbanist,sans-serif;color:#5c7487}.cot-modal-header{padding:1rem 1.1rem;border-bottom:1px solid rgb(13 48 75 / .12);background:linear-gradient(145deg,#0d304bf5,#134162eb);color:#fff;display:flex;justify-content:space-between;align-items:flex-start;gap:.8rem}.cot-modal-title-wrap h2{margin:0;font-family:Archivo,sans-serif;font-size:1.3rem}.cot-modal-kicker{display:inline-block;margin-bottom:.35rem;font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#f0f9ffb8;font-family:Urbanist,sans-serif}.cot-modal-top-actions{display:flex;align-items:center;gap:.58rem}.cot-modal-close{border:none;width:30px;height:30px;border-radius:8px;background:#ffffff1a;color:#fff;cursor:pointer;display:grid;place-items:center;font-family:Urbanist,sans-serif;font-size:.9rem}.cot-modal-close:hover{background:#fff3}.cot-alert-modal{margin:.9rem 1rem 0}.cot-modal-content{padding:1rem 1.1rem;display:grid;gap:.85rem}.cot-modal-section{border-radius:14px;border:1px solid rgb(13 48 75 / .1);background:#fff;padding:.84rem}.cot-modal-section h3{margin:0 0 .66rem;color:var(--cot-navy);font-family:Urbanist,sans-serif;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em}.cot-info-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem}.cot-info-item{border-radius:12px;border:1px solid #dbe7f2;background:#f8fbff;padding:.72rem;display:grid;gap:.3rem}.cot-info-item span{font-family:Urbanist,sans-serif;font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:#64748b;font-weight:700}.cot-info-item strong{color:#0f172a;font-family:Urbanist,sans-serif;font-size:.86rem;line-height:1.45}.cot-section-head{display:flex;justify-content:space-between;align-items:center;gap:.65rem;margin-bottom:.65rem}.cot-section-head h3{margin:0}.cot-items-wrap{overflow-x:auto}.cot-items-table{width:100%;border-collapse:collapse}.cot-items-table thead{background:#f4f9ff}.cot-items-table th{text-align:left;font-family:Urbanist,sans-serif;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:#546d7e;padding:.55rem}.cot-items-table td{border-top:1px solid #e6edf5;font-family:Urbanist,sans-serif;font-size:.83rem;color:#2d4457;padding:.62rem .55rem}.cot-empty-items{margin:0 0 .72rem;color:#667f90;font-family:Urbanist,sans-serif;font-size:.88rem}.cot-resumen-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem}.cot-resumen-item{border-radius:12px;border:1px solid #dbe7f2;background:linear-gradient(180deg,#f8fbff,#fff);padding:.7rem;display:grid;gap:.24rem}.cot-resumen-item span{font-family:Urbanist,sans-serif;font-size:.67rem;text-transform:uppercase;letter-spacing:.07em;color:#667085}.cot-resumen-item strong{font-family:Archivo,sans-serif;color:#1f2937;font-size:.97rem}.cot-resumen-item-total{grid-column:span 2;border-color:#9be8c8;background:linear-gradient(135deg,#ecfff6,#d8fbe9)}.cot-resumen-item-total strong{color:#0e8a5b;font-size:1.08rem}.cot-modal-footer{padding:.9rem 1.1rem 1.1rem;border-top:1px solid rgb(13 48 75 / .12);display:flex;flex-wrap:wrap;gap:.52rem;justify-content:flex-end}@media (max-width: 1080px){.cot-hero{grid-template-columns:1fr}.cot-filters-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.cot-field-wide{grid-column:span 2}}@media (max-width: 760px){.cot-shell{width:calc(100% - 1rem);padding:1rem 0 1.3rem}.cot-card,.cot-hero-summary,.cot-hero-copy{border-radius:16px}.cot-form-row,.cot-filters-grid,.cot-info-grid,.cot-resumen-grid{grid-template-columns:1fr}.cot-field-wide,.cot-resumen-item-total{grid-column:span 1}.cot-field-sm{max-width:none}.cot-filters-header,.cot-list-header,.cot-section-head,.cot-modal-header{flex-direction:column;align-items:stretch}.cot-list-chip{width:fit-content}.cot-modal{border-radius:16px;max-height:94vh}.cot-modal-top-actions,.cot-modal-footer,.cot-form-actions{flex-direction:column;align-items:stretch}.cot-page .btn,.cot-action-btn{width:100%}.cot-actions-cell{min-width:190px}}@media (max-width: 560px){.cot-table th:nth-child(4),.cot-table td:nth-child(4),.cot-table th:nth-child(5),.cot-table td:nth-child(5){display:none}}@keyframes cotSpin{to{transform:rotate(360deg)}}@keyframes cotFadeIn{0%{opacity:0}to{opacity:1}}@keyframes cotSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes cotFadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.historial-container{background:#fff;border-radius:8px;border:1px solid #e0e0e0;padding:20px;margin:20px 0;box-shadow:0 2px 4px #0000001a}.historial-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #00CCCC}.historial-header h3{margin:0;color:#333;font-size:18px;font-weight:600}.btn-refresh{background:none;border:1px solid #ddd;padding:6px 10px;border-radius:4px;cursor:pointer;font-size:16px;transition:all .3s ease}.btn-refresh:hover{background:#f5f5f5;border-color:#0cc;transform:rotate(180deg)}.historial-error{background:#fee;border:1px solid #fcc;border-radius:4px;padding:12px;margin-bottom:15px;color:#c33;font-size:13px}.historial-estadisticas{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid #f0f0f0}.stat-item{display:flex;align-items:center;gap:8px;padding:10px;background:#f9f9f9;border-radius:6px;border-left:3px solid #00CCCC}.stat-icon{font-size:18px;min-width:24px}.stat-text{font-size:13px;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stat-text strong{color:#0cc;font-weight:700}.historial-filtros{margin-bottom:20px;display:flex;align-items:center;gap:10px;padding:10px;background:#f5f5f5;border-radius:6px}.historial-filtros label{font-weight:600;color:#333;font-size:13px;white-space:nowrap}.filtro-select{padding:6px 10px;border:1px solid #ddd;border-radius:4px;font-size:13px;background:#fff;color:#333;cursor:pointer;transition:border-color .3s ease}.filtro-select:hover,.filtro-select:focus{border-color:#0cc;outline:none;box-shadow:0 0 0 2px #00cccc1a}.historial-timeline{margin:20px 0}.sin-eventos{text-align:center;color:#999;padding:20px;font-size:14px;background:#f9f9f9;border-radius:6px}.timeline-item{display:flex;gap:15px;margin-bottom:20px;position:relative}.timeline-item:not(:last-child):after{content:"";position:absolute;left:19px;top:50px;width:2px;height:calc(100% + 10px);background:linear-gradient(180deg,#00CCCC,transparent)}.timeline-marker{display:flex;justify-content:center;align-items:center;min-width:40px;height:40px;background:#fff;border:2px solid #00CCCC;border-radius:50%;position:relative;z-index:1}.timeline-icon{font-size:20px}.timeline-content{flex:1;background:#f9f9f9;border-radius:6px;border-left:3px solid #00CCCC;padding:12px 15px}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:10px}.evento-tipo{font-weight:700;color:#0cc;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.evento-fecha{font-size:12px;color:#999;white-space:nowrap}.timeline-body{font-size:13px;color:#666}.evento-usuario{margin:5px 0;padding:8px;background:#fff;border-radius:4px;font-size:12px}.usuario-email{color:#999;font-style:italic}.evento-descripcion{margin:8px 0;background:#fff;border-radius:4px;line-height:1.4;border-left:2px solid #00CCCC;padding:8px 8px 8px 10px}.evento-cambio{margin:10px 0;padding:10px;background:#fff;border-radius:4px;border:1px solid #e0e0e0}.cambio-campo{display:block;margin-bottom:8px;font-weight:600;color:#333}.cambio-campo code{background:#f0f0f0;padding:2px 6px;border-radius:3px;font-family:Courier New,monospace;color:#06c;font-size:12px}.cambio-valores{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:12px}.valor-anterior code,.valor-nuevo code{background:#f5f5f5;padding:4px 8px;border-radius:3px;font-family:Courier New,monospace;max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-block}.valor-anterior{color:#c33}.valor-anterior code{background:#ffebee;color:#c33}.flecha{color:#999;font-weight:700}.valor-nuevo{color:#0a6}.valor-nuevo code{background:#ecf8f5;color:#0a6}.evento-metadatos{margin-top:10px;cursor:pointer}.evento-metadatos summary{font-weight:600;color:#0cc;font-size:12px;-webkit-user-select:none;user-select:none;padding:5px;border-radius:3px;transition:background-color .2s ease}.evento-metadatos summary:hover{background:#00cccc1a}.evento-metadatos pre{background:#f0f0f0;border:1px solid #ddd;border-radius:4px;padding:10px;overflow-x:auto;font-size:11px;line-height:1.3;color:#333;margin:8px 0 0;max-height:300px;overflow-y:auto}.historial-footer{text-align:center;font-size:12px;color:#999;padding-top:15px;border-top:1px solid #f0f0f0;margin-top:20px}@media (max-width: 768px){.historial-container{padding:15px;margin:15px 0}.historial-header{flex-direction:column;align-items:flex-start;gap:10px}.historial-estadisticas{grid-template-columns:repeat(2,1fr);gap:8px}.timeline-header{flex-direction:column;align-items:flex-start}.evento-fecha{font-size:11px}.cambio-valores{flex-direction:column;align-items:flex-start}.flecha{margin-left:5px}}@media (max-width: 480px){.historial-container{padding:10px;margin:10px 0}.historial-header h3{font-size:16px}.historial-filtros{flex-direction:column;align-items:flex-start}.timeline-item{gap:10px}.timeline-content{padding:10px 12px}.evento-usuario,.evento-descripcion,.evento-cambio{font-size:12px;padding:8px}}.notas-panel{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px;margin:20px 0;box-shadow:0 1px 3px #0000001a}.notas-titulo{font-size:18px;font-weight:600;margin:0 0 20px;color:#1f2937;display:flex;align-items:center;gap:8px}.notas-alerta{padding:12px 16px;border-radius:6px;margin-bottom:16px;font-size:14px;display:flex;align-items:center;gap:8px}.notas-alerta.error{background-color:#fee2e2;color:#991b1b;border:1px solid #fecaca}.notas-alerta.exito{background-color:#dcfce7;color:#166534;border:1px solid #86efac}.notas-formulario{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:16px;margin-bottom:20px}.notas-form-grupo{margin-bottom:12px;display:flex;flex-direction:column;gap:6px}.notas-form-grupo label{font-weight:500;color:#374151;font-size:14px}.notas-select,.notas-textarea{border:1px solid #d1d5db;border-radius:4px;padding:8px 12px;font-size:14px;font-family:inherit}.notas-select:focus,.notas-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.notas-textarea{resize:vertical;min-height:60px;color:#1f2937}.notas-boton-crear{background:#3b82f6;color:#fff;border:none;border-radius:4px;padding:10px 16px;font-weight:500;cursor:pointer;font-size:14px;transition:background .2s;margin-top:8px}.notas-boton-crear:hover{background:#2563eb}.notas-boton-crear:active{background:#1d4ed8}.notas-filtro{display:flex;align-items:center;gap:12px;margin-bottom:20px;background:#f3f4f6;padding:12px;border-radius:6px}.notas-filtro label{font-weight:500;color:#374151;font-size:14px;white-space:nowrap}.notas-select-filtro{border:1px solid #d1d5db;border-radius:4px;padding:6px 10px;font-size:14px;flex:1;max-width:300px}.notas-select-filtro:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.notas-lista{display:flex;flex-direction:column;gap:12px}.notas-cargando{text-align:center;color:#6b7280;padding:20px;font-style:italic}.notas-vacia{text-align:center;color:#9ca3af;padding:40px 20px;background:#f9fafb;border:2px dashed #e5e7eb;border-radius:6px}.notas-item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:12px;transition:all .2s}.notas-item:hover{background:#fff;box-shadow:0 1px 3px #0000001a;border-color:#d1d5db}.notas-header{display:flex;align-items:center;gap:12px;margin-bottom:8px;flex-wrap:wrap}.notas-badge{display:inline-block;padding:4px 8px;border-radius:4px;color:#fff;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.notas-autor{font-weight:600;color:#1f2937;font-size:14px}.notas-fecha{color:#6b7280;font-size:12px;margin-left:auto}.notas-contenido{color:#374151;line-height:1.5;margin:8px 0;word-wrap:break-word;white-space:pre-wrap}.notas-botones{display:flex;gap:8px;margin-top:8px;padding-top:8px;border-top:1px solid #e5e7eb}.notas-boton-editar,.notas-boton-eliminar,.notas-boton-guardar,.notas-boton-cancelar{padding:6px 12px;border:1px solid #d1d5db;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;background:#fff}.notas-boton-editar{color:#3b82f6;border-color:#3b82f6}.notas-boton-editar:hover{background:#eff6ff}.notas-boton-eliminar{color:#ef4444;border-color:#ef4444}.notas-boton-eliminar:hover{background:#fef2f2}.notas-boton-guardar{background:#10b981;color:#fff;border-color:#10b981}.notas-boton-guardar:hover{background:#059669}.notas-boton-cancelar{background:#ef4444;color:#fff;border-color:#ef4444}.notas-boton-cancelar:hover{background:#dc2626}.notas-edicion{padding:12px 0}.notas-textarea-edit{width:100%;border:1px solid #3b82f6;border-radius:4px;padding:10px;font-family:inherit;font-size:14px;resize:vertical;min-height:100px;color:#1f2937}.notas-textarea-edit:focus{outline:none;box-shadow:0 0 0 3px #3b82f61a}.notas-botones-edicion{display:flex;gap:8px;margin-top:8px}@media (max-width: 768px){.notas-panel{padding:16px}.notas-formulario{padding:12px}.notas-filtro{flex-direction:column;align-items:flex-start;gap:8px}.notas-select-filtro{width:100%;max-width:none}.notas-header{flex-direction:column;align-items:flex-start}.notas-fecha{margin-left:0}.notas-botones{flex-wrap:wrap}}.edicion-page{--edit-cyan: #2ec7c2;--edit-cyan-deep: #16aca7;--edit-navy: #0d304b;--edit-ink-soft: #556e7f;--edit-surface: rgb(255 255 255 / .9);min-height:100vh;background:radial-gradient(940px 560px at 6% 8%,rgb(46 199 194 / .13),transparent 62%),radial-gradient(900px 520px at 95% 92%,rgb(13 48 75 / .11),transparent 62%),linear-gradient(180deg,#f6fbff,#edf4fb 58%,#e8f0f8)}.edicion-container{width:min(1320px,calc(100% - 2rem));margin:0 auto;padding:2rem 0 2.4rem;display:grid;gap:1.15rem}.loading-spinner,.error-box,.edicion-header,.edicion-form,.resumen-card,.info-box{border-radius:22px;border:1px solid rgb(255 255 255 / .95);background:var(--edit-surface);box-shadow:0 22px 38px #112e4817}.loading-spinner{min-height:250px;display:grid;place-items:center;text-align:center;gap:.8rem;color:#60798a;font-family:Urbanist,sans-serif;font-weight:600}.loading-spinner:before{content:"";width:46px;height:46px;border:4px solid rgb(46 199 194 / .22);border-top-color:var(--edit-cyan-deep);border-radius:50%;animation:editSpin .9s linear infinite}.error-box{min-height:250px;display:grid;place-items:center;text-align:center;gap:1rem;padding:2rem}.error-box p{margin:0;font-family:Urbanist,sans-serif;color:#9b1c1c;font-size:1rem;font-weight:700}.edicion-header{display:grid;grid-template-columns:minmax(0,1.65fr) minmax(280px,.95fr);gap:1rem;align-items:center;padding:clamp(1.25rem,2.8vw,1.9rem);background:linear-gradient(145deg,#ffffffdb,#ffffffad),linear-gradient(125deg,#2ec7c224,#2ec7c208);animation:editFadeUp .42s ease both}.edicion-header h1{margin:0;font-family:Archivo,sans-serif;font-weight:800;font-size:clamp(1.65rem,2.7vw,2.3rem);letter-spacing:-.02em;line-height:1.12;color:var(--edit-navy)}.edicion-header h1 span{color:#16aca7}.subtitulo{margin:.76rem 0 0;max-width:60ch;font-family:Urbanist,sans-serif;color:var(--edit-ink-soft);font-size:.95rem;line-height:1.5}.header-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:.6rem}.edicion-page .alert{border-radius:14px;padding:.84rem .95rem;font-family:Urbanist,sans-serif;font-size:.88rem;font-weight:600;animation:editSlideDown .25s ease}.edicion-page .alert-error{border:1px solid rgb(248 113 113 / .34);background:#fee2e2db;color:#8e2424}.edicion-page .alert-success{border:1px solid rgb(74 222 128 / .35);background:#dcfce7db;color:#166534}.edicion-content{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(300px,.8fr);gap:1rem}.edicion-form{overflow:hidden}.form-section{padding:1rem;border-bottom:1px solid rgb(13 48 75 / .12)}.form-section:last-of-type{border-bottom:none}.form-section h2,.form-section h3{margin:0 0 .78rem;font-family:Archivo,sans-serif;color:var(--edit-navy);letter-spacing:-.01em}.form-section h2{font-size:1.18rem}.form-section h3{font-size:1.05rem}.form-section h4{margin:.8rem 0 .65rem;font-family:Urbanist,sans-serif;font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:#5a7385}.form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.72rem;margin-bottom:.72rem}.form-group{display:grid;gap:.32rem}.form-group label{margin:0;font-family:Urbanist,sans-serif;font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#526d80}.form-group input,.form-group select,.form-group textarea{width:100%;border-radius:11px;border:1px solid rgb(13 48 75 / .18);background:#fff;padding:.64rem .75rem;font-family:Urbanist,sans-serif;font-size:.87rem;color:#18344a;transition:border-color .2s ease,box-shadow .2s ease}.form-group textarea{resize:vertical;min-height:94px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--edit-cyan-deep);box-shadow:0 0 0 3px #2ec7c22e}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background:#f3f8fc;color:#7f95a4;cursor:not-allowed}.descuento-input-group{display:grid;gap:.34rem}.descuento-info{font-family:Urbanist,sans-serif;font-size:.75rem;color:#6c8493}.section-header{display:flex;justify-content:space-between;align-items:center;gap:.72rem;margin-bottom:.8rem}.section-header h3{margin:0}.items-lista{display:grid;gap:.72rem}.item-card{border-radius:14px;border:1px solid rgb(13 48 75 / .14);background:linear-gradient(180deg,#f8fcfff2,#fffffff5);padding:.86rem;transition:border-color .2s ease,box-shadow .2s ease}.item-card:hover{border-color:#16aca773;box-shadow:0 12px 20px #112e4814}.item-header{display:flex;justify-content:space-between;align-items:center;gap:.65rem;margin-bottom:.7rem;padding-bottom:.62rem;border-bottom:1px solid rgb(13 48 75 / .12)}.item-header h4{margin:0;font-family:Archivo,sans-serif;color:var(--edit-navy);font-size:1rem}.item-actions{display:flex;gap:.4rem;flex-wrap:wrap}.item-body p{margin:0 0 .45rem;font-family:Urbanist,sans-serif;font-size:.85rem;color:#2f4a5e;line-height:1.46}.item-meta{color:#4b6578}.item-file-input{display:none}.item-image-tools{margin:.65rem 0 .86rem;padding:.72rem;border-radius:12px;border:1px solid #dce8f2;background:#f8fcff}.item-image-thumb{width:100%;max-height:170px;object-fit:contain;border:1px solid #dbe3ee;border-radius:10px;background:#fff;margin-bottom:.6rem}.item-image-actions{display:flex;flex-wrap:wrap;gap:.44rem}.item-image-actions .btn{min-height:33px;padding:.4rem .68rem}.item-costos{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:.38rem;margin-bottom:.62rem}.item-costos span{font-size:.77rem;color:#4f6779;padding:.38rem .5rem;border-radius:9px;background:#fffffff0;border:1px solid #dce8f2;font-family:Urbanist,sans-serif}.item-total{text-align:right;font-family:Urbanist,sans-serif;font-size:.92rem;color:#0f8f61;padding-top:.52rem;border-top:1px solid rgb(13 48 75 / .1)}.empty-state{border-radius:14px;border:1px dashed rgb(13 48 75 / .25);background:#ffffff9e;min-height:128px;display:grid;place-items:center;text-align:center;color:#5f7889;font-family:Urbanist,sans-serif;font-size:.92rem;padding:1rem}.empty-state p{margin:0}.item-form-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a17238f;display:flex;justify-content:center;align-items:center;z-index:1000;padding:18px;animation:editFadeIn .2s ease}.item-form-modal{width:min(860px,100%);max-height:92vh;overflow-y:auto;border-radius:20px;border:1px solid rgb(255 255 255 / .92);background:#fff;box-shadow:0 28px 60px #0a172359;animation:editSlideUp .24s ease}.item-form-modal h3{margin:0;padding:1rem 1.1rem;border-bottom:1px solid rgb(13 48 75 / .12);background:linear-gradient(145deg,#0d304bf5,#134162eb);color:#fff;font-family:Archivo,sans-serif;font-size:1.16rem}.item-form-body{padding:1rem 1.1rem}.item-form-modal .form-group{margin-bottom:.7rem}.item-form-modal .checkbox-inline{display:flex;justify-content:flex-end;align-items:center}.item-form-modal .checkbox-inline label{display:inline-flex;align-items:center;gap:.4rem;margin-top:1.5rem}.item-form-modal .checkbox-inline input{width:16px;height:16px;accent-color:var(--edit-cyan-deep)}.precio-calculado{display:flex;justify-content:space-between;align-items:center;padding:.78rem;background:linear-gradient(135deg,#ecfff6,#d8fbe9);border:1px solid #9be8c8;border-radius:12px;margin:.25rem 0 .82rem}.precio-calculado strong{color:#196443;font-size:.85rem;font-family:Urbanist,sans-serif}.precio-calculado span{color:#0e8a5b;font-size:1.2rem;font-family:Archivo,sans-serif}.edicion-form>.form-actions{display:flex;gap:.55rem;padding:.95rem 1rem 1rem;border-top:1px solid rgb(13 48 75 / .12);background:#f8fcffdb;flex-wrap:wrap}.item-form-modal .form-actions{display:flex;gap:.5rem;justify-content:flex-end;flex-wrap:wrap;padding:0;border:none;background:transparent}.edicion-resumen{display:grid;gap:.9rem;align-content:start;position:sticky;top:86px;height:fit-content}.resumen-card{padding:1rem}.resumen-card h3{margin:0;font-family:Archivo,sans-serif;color:var(--edit-navy);font-size:1.16rem}.resumen-section{margin-top:.84rem;padding-top:.84rem;border-top:1px solid rgb(13 48 75 / .12)}.resumen-section h4{margin:0 0 .55rem;font-family:Urbanist,sans-serif;color:#5a7385;font-size:.73rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.resumen-cantidad{margin:0;font-family:Archivo,sans-serif;color:#0f4f8a;font-size:1.08rem}.resumen-item{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem;padding:.35rem 0;font-family:Urbanist,sans-serif;font-size:.85rem;color:#4f6779}.resumen-item strong{color:#20384b}.descuento-valor{color:#b4233a;font-weight:700}.resumen-total{border-radius:14px;border:1px solid #9be8c8;background:linear-gradient(135deg,#ecfff6,#d8fbe9);padding:.74rem}.resumen-item.total{margin:0;padding:0;font-size:1rem;font-weight:700}.resumen-total-valor{color:#0e8a5b;font-family:Archivo,sans-serif;font-size:1.55rem}.edicion-resumen .badge{display:inline-flex;align-items:center;justify-content:center;width:24px;margin-right:.35rem}.resumen-card p{margin:.36rem 0;font-family:Urbanist,sans-serif;font-size:.84rem;color:#4f6779}.info-box{padding:.95rem;border-radius:18px;border:1px solid rgb(245 158 11 / .3);background:linear-gradient(145deg,#fffbebed,#fef3c780)}.info-box h4{margin:0 0 .55rem;color:#8a5c15;font-family:Archivo,sans-serif;font-size:1rem}.info-box ul{margin:0;padding-left:1.1rem;color:#815d1f;font-family:Urbanist,sans-serif;font-size:.81rem;line-height:1.48}.info-box li{margin:.26rem 0}.edicion-header .btn,.edicion-form .btn,.item-form-modal .btn,.error-box .btn{border:none;border-radius:11px;min-height:38px;padding:.52rem .88rem;font-family:Urbanist,sans-serif;font-size:.83rem;font-weight:700;cursor:pointer;transition:transform .16s ease,box-shadow .2s ease,filter .2s ease}.edicion-header .btn:hover,.edicion-form .btn:hover,.item-form-modal .btn:hover,.error-box .btn:hover,.edicion-header .btn:focus-visible,.edicion-form .btn:focus-visible,.item-form-modal .btn:focus-visible,.error-box .btn:focus-visible{transform:translateY(-1px)}.edicion-header .btn-primary,.edicion-form .btn-primary,.item-form-modal .btn-primary,.error-box .btn-primary{background:linear-gradient(135deg,var(--edit-cyan),var(--edit-cyan-deep));color:#fff;box-shadow:0 10px 20px #16aca73d}.edicion-header .btn-secondary,.edicion-form .btn-secondary,.item-form-modal .btn-secondary,.error-box .btn-secondary{background:linear-gradient(135deg,#5a748d,#3d576f);color:#fff;box-shadow:0 10px 18px #3d576f38}.edicion-header .btn-success,.edicion-form .btn-success,.item-form-modal .btn-success,.error-box .btn-success{background:linear-gradient(135deg,#1fa36b,#0f8a5a);color:#fff;box-shadow:0 10px 18px #0f8a5a3d}.edicion-header .btn-danger,.edicion-form .btn-danger,.item-form-modal .btn-danger,.error-box .btn-danger{background:linear-gradient(135deg,#e4546d,#be2f49);color:#fff;box-shadow:0 10px 18px #be2f493d}.edicion-header .btn-info,.edicion-form .btn-info,.item-form-modal .btn-info,.error-box .btn-info{background:linear-gradient(135deg,#3d80c8,#2860a2);color:#fff;box-shadow:0 10px 18px #2860a23d}.edicion-header .btn-warning,.edicion-form .btn-warning,.item-form-modal .btn-warning,.error-box .btn-warning{background:linear-gradient(135deg,#f3b74d,#dc9020);color:#4a2e04;box-shadow:0 10px 18px #dc90203d}.edicion-header .btn-sm,.edicion-form .btn-sm,.item-form-modal .btn-sm,.error-box .btn-sm{min-height:32px;padding:.35rem .62rem;font-size:.75rem}.edicion-header .btn:disabled,.edicion-form .btn:disabled,.item-form-modal .btn:disabled,.error-box .btn:disabled{opacity:.68;cursor:not-allowed;transform:none;box-shadow:none}@media (max-width: 1160px){.edicion-header{grid-template-columns:1fr}.header-actions{justify-content:flex-start}.edicion-content{grid-template-columns:1fr}.edicion-resumen{position:static}}@media (max-width: 860px){.edicion-container{width:calc(100% - 1rem);padding:1rem 0 1.3rem}.edicion-header,.edicion-form,.resumen-card,.info-box,.loading-spinner,.error-box{border-radius:16px}.form-row,.item-form-modal .form-row{grid-template-columns:1fr;gap:.6rem}.section-header,.item-header{flex-direction:column;align-items:flex-start}.item-actions,.item-image-actions,.edicion-form>.form-actions,.item-form-modal .form-actions,.header-actions{width:100%}.item-actions .btn,.item-image-actions .btn,.edicion-form>.form-actions .btn,.item-form-modal .form-actions .btn,.header-actions .btn{width:100%}.item-form-modal{max-height:94vh;border-radius:16px}.item-form-modal h3{border-radius:16px 16px 0 0}.item-form-modal .checkbox-inline{justify-content:flex-start}.item-form-modal .checkbox-inline label{margin-top:0}}@media (max-width: 560px){.edicion-header h1{font-size:1.45rem}.subtitulo{font-size:.86rem}.form-section{padding:.86rem}.resumen-total-valor{font-size:1.32rem}.item-costos{grid-template-columns:1fr}}@keyframes editSpin{to{transform:rotate(360deg)}}@keyframes editSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes editFadeIn{0%{opacity:0}to{opacity:1}}@keyframes editSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes editFadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.admin-page{--admin-cyan: #2ec7c2;--admin-cyan-deep: #16aca7;--admin-navy: #0d304b;--admin-ink-soft: #526b7c;--admin-surface: #f5fbfd;min-height:100vh;background:radial-gradient(920px 560px at 3% 12%,rgb(46 199 194 / .13),transparent 64%),radial-gradient(900px 540px at 97% 88%,rgb(13 48 75 / .1),transparent 62%),linear-gradient(180deg,#f6fbff,#eef5fa 58%,#e8f0f8)}.admin-shell{max-width:1320px;margin:0 auto;padding:2rem 1.4rem 2.4rem;display:grid;gap:1.15rem}.admin-hero{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(300px,.95fr);gap:1.1rem}.admin-hero-content,.admin-hero-summary{border-radius:22px;border:1px solid rgb(255 255 255 / .95);box-shadow:0 22px 38px #112e4817}.admin-hero-content{padding:clamp(1.3rem,2.8vw,2rem);background:linear-gradient(145deg,#ffffffdb,#ffffffad),linear-gradient(125deg,#2ec7c224,#2ec7c20a);animation:adminFadeUp .46s ease both}.admin-eyebrow{display:inline-flex;margin-bottom:.85rem;padding:.34rem .75rem;border-radius:999px;background:#0d304b14;color:var(--admin-navy);font-family:Urbanist,sans-serif;letter-spacing:.09em;text-transform:uppercase;font-size:.73rem;font-weight:700}.admin-hero-content h1{margin:0 0 .7rem;font-family:Archivo,sans-serif;font-weight:800;font-size:clamp(1.65rem,2.8vw,2.35rem);line-height:1.15;color:var(--admin-navy);letter-spacing:-.02em}.admin-hero-description{margin:0;max-width:64ch;font-family:Urbanist,sans-serif;color:var(--admin-ink-soft);font-size:1rem;line-height:1.56}.admin-hero-pills{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1rem}.admin-pill{border-radius:999px;padding:.34rem .82rem;background:linear-gradient(135deg,var(--admin-cyan),var(--admin-cyan-deep));color:#fff;font-family:Urbanist,sans-serif;font-size:.8rem;font-weight:700}.admin-pill-soft{background:#0d304b17;color:var(--admin-navy);font-weight:600}.admin-hero-summary{padding:1.2rem 1.2rem 1.1rem;background:linear-gradient(145deg,#0d304bf5,#134162eb);color:#fff;display:grid;align-content:start;gap:.8rem;animation:adminFadeUp .56s ease 60ms both}.admin-hero-summary h2{margin:0;font-family:Archivo,sans-serif;font-size:1.2rem;font-weight:700}.summary-item{padding:.82rem;border-radius:12px;border:1px solid rgb(255 255 255 / .16);background:#ffffff14;display:flex;align-items:center;justify-content:space-between;gap:.7rem;font-family:Urbanist,sans-serif}.summary-label{font-size:.82rem;color:#f0f9ffcc}.summary-item strong{font-size:.95rem}.admin-sections{display:flex;flex-wrap:wrap;gap:.65rem}.section-btn{border:none;border-radius:11px;min-height:40px;padding:.62rem 1rem;font-family:Urbanist,sans-serif;font-size:.88rem;font-weight:700;color:var(--admin-navy);background:#0d304b14;cursor:pointer;transition:transform .16s ease,box-shadow .2s ease,background-color .2s ease}.section-btn:hover{transform:translateY(-1px);background:#0d304b21}.section-btn.active{color:#fff;background:linear-gradient(135deg,var(--admin-cyan),var(--admin-cyan-deep));box-shadow:0 12px 22px #16aca747}.admin-content{border-radius:20px;border:1px solid rgb(255 255 255 / .94);background:#ffffffdb;box-shadow:0 18px 30px #112e4814;padding:1.15rem;animation:adminFadeUp .62s ease 80ms both}.type-tabs{display:flex;flex-wrap:wrap;gap:.55rem;margin-bottom:1rem;padding-bottom:.95rem;border-bottom:1px solid rgb(13 48 75 / .1)}.type-tab{border:none;border-radius:10px;padding:.5rem .85rem;background:#0d304b14;color:var(--admin-navy);font-family:Urbanist,sans-serif;font-size:.83rem;font-weight:700;cursor:pointer;transition:transform .15s ease,background-color .2s ease}.type-tab:hover{transform:translateY(-1px);background:#0d304b21}.type-tab.active{color:#fff;background:linear-gradient(135deg,var(--admin-cyan),var(--admin-cyan-deep))}.table-actions{margin-bottom:.95rem;display:flex;justify-content:flex-end}.admin-table-wrap,.productos-table-wrap{overflow-x:auto;border-radius:14px;border:1px solid rgb(13 48 75 / .08);background:#fff}.admin-page .table{margin-top:0}.admin-page .table th,.admin-page .table td{border-bottom:1px solid rgb(13 48 75 / .09);vertical-align:middle}.admin-page .table th{text-transform:none;letter-spacing:.01em;font-family:Urbanist,sans-serif;font-size:.8rem;font-weight:700;color:var(--admin-navy);background:#f2f8fd}.admin-page .table td{font-family:Urbanist,sans-serif;color:#304a5d;font-size:.88rem}.admin-page .table tbody tr:hover{background:#f6fcff}.admin-inline-actions,.productos-actions{display:flex;flex-wrap:wrap;align-items:center;gap:.45rem}.admin-page .btn{border-radius:10px;font-family:Urbanist,sans-serif;font-weight:700;transition:transform .15s ease,box-shadow .18s ease,filter .2s ease}.admin-page .btn:hover:not(:disabled){transform:translateY(-1px);filter:saturate(1.04)}.btn-sm{padding:.4rem .72rem;font-size:.78rem}.badge{display:inline-block;padding:.28rem .66rem;border-radius:999px;font-family:Urbanist,sans-serif;font-size:.74rem;font-weight:700;letter-spacing:.01em}.badge-primary{color:#fff;background:linear-gradient(135deg,#2a67d4,#2457b4)}.badge-secondary{color:#24465c;background:#dce9f3}.badge-success{color:#fff;background:linear-gradient(135deg,#2bb673,#17945a)}.badge-danger{color:#fff;background:linear-gradient(135deg,#e84c5e,#cc3143)}.col-image{width:56px}.table-meta{font-size:.84rem}.prod-name{font-weight:700;color:var(--admin-navy);display:block}.prod-variant{color:#6e8393;font-size:.8rem;display:block}.productos-img-cell{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#f1f7fb;border-radius:6px;overflow:hidden}.productos-img-thumb{max-width:48px;max-height:48px;object-fit:contain}.productos-img-placeholder{font-size:.85rem;color:#90a6b5}.productos-descripcion{display:block;margin-top:.3rem;font-size:.79rem;color:#658092;line-height:1.35;white-space:pre-line}.row-inactivo td{opacity:.6}.productos-toolbar{display:flex;justify-content:space-between;align-items:center;gap:.8rem;margin-bottom:.95rem;flex-wrap:wrap}.productos-filter{flex:1;min-width:200px;max-width:320px}.productos-filter .select{width:100%}.productos-empty{padding:2rem;text-align:center;color:#6f8695;font-family:Urbanist,sans-serif;font-size:.95rem}.admin-page .select,.admin-page .input,.admin-page .producto-textarea{border-radius:10px;border:1px solid rgb(13 48 75 / .16);background:#f7fcff;font-family:Urbanist,sans-serif}.admin-page .select:focus,.admin-page .input:focus,.admin-page .producto-textarea:focus{outline:none;border-color:var(--admin-cyan-deep);box-shadow:0 0 0 3px #2ec7c22e}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0b182485;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal-content{background:#fff;border-radius:18px;width:90%;max-width:560px;border:1px solid rgb(255 255 255 / .94);box-shadow:0 24px 50px #0b182447;animation:slideUp .28s ease}.modal-header{padding:1rem 1.1rem;border-bottom:1px solid rgb(13 48 75 / .1);display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0;color:var(--admin-navy);font-family:Archivo,sans-serif;font-size:1.08rem}.close-btn{background:#0d304b14;border:none;width:2rem;height:2rem;border-radius:8px;color:var(--admin-navy);font-size:1.25rem;line-height:1;cursor:pointer;display:grid;place-items:center}.close-btn:hover{background:#0d304b21}.modal-body{padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.85rem}.admin-page .form-group{display:grid;gap:.35rem}.admin-page .form-group label{font-family:Urbanist,sans-serif;color:var(--admin-navy);font-size:.82rem;font-weight:700}.modal-footer{padding:1rem 1.1rem;border-top:1px solid rgb(13 48 75 / .1);display:flex;justify-content:flex-end;gap:.65rem}.modal-producto-form{max-width:620px}.producto-textarea{min-height:92px;resize:vertical}.prod-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}@media (max-width: 1060px){.admin-hero{grid-template-columns:1fr}.admin-hero-summary{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));align-items:stretch}.admin-hero-summary h2{grid-column:1 / -1}}@media (max-width: 760px){.admin-shell{padding:1rem .75rem 1.3rem}.section-btn{flex:1 1 100%}.type-tabs,.productos-toolbar{display:grid;grid-template-columns:1fr}.productos-filter{max-width:none}.table-actions{justify-content:stretch}.table-actions .btn{width:100%}.modal-footer{display:grid;grid-template-columns:1fr}.modal-footer .btn{width:100%}}@media (max-width: 500px){.prod-form-row{grid-template-columns:1fr}}@keyframes slideUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes adminFadeUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.fin-page{--fin-cyan: #2ec7c2;--fin-cyan-deep: #16aca7;--fin-navy: #0d304b;--fin-ink-soft: #526b7c;--fin-surface: #f5fbfd;min-height:100vh;background:radial-gradient(920px 560px at 3% 12%,rgb(46 199 194 / .13),transparent 64%),radial-gradient(900px 540px at 97% 88%,rgb(13 48 75 / .1),transparent 62%),linear-gradient(180deg,#f6fbff,#eef5fa 58%,#e8f0f8)}.fin-shell{width:min(1320px,calc(100% - 2rem));margin:0 auto;padding:2rem 1.4rem 2.4rem;display:grid;gap:1.15rem}.fin-hero,.fin-filters,.fin-kpis,.fin-card,.fin-alert{border-radius:22px;border:1px solid rgb(255 255 255 / .95);box-shadow:0 22px 38px #112e4817}.fin-hero{padding:clamp(1.3rem,2.8vw,2rem);background:linear-gradient(145deg,#ffffffdb,#ffffffad),linear-gradient(125deg,#2ec7c224,#2ec7c20a);animation:finFadeUp .46s ease both}.fin-kicker{display:inline-flex;margin-bottom:.78rem;padding:.34rem .75rem;border-radius:999px;background:#0d304b14;color:var(--fin-navy);font-family:Urbanist,sans-serif;letter-spacing:.09em;text-transform:uppercase;font-size:.73rem;font-weight:700}.fin-hero h1{margin:0;color:var(--fin-navy);font-family:Archivo,sans-serif;font-weight:800;font-size:clamp(1.65rem,2.8vw,2.35rem);line-height:1.15;letter-spacing:-.02em}.fin-hero p{margin:.78rem 0 0;max-width:68ch;color:var(--fin-ink-soft);font-family:Urbanist,sans-serif;font-size:1rem;line-height:1.56}.fin-filters{padding:1rem 1.05rem;background:#ffffffdb;display:grid;gap:.8rem;grid-template-columns:repeat(3,minmax(160px,1fr)) minmax(260px,auto);align-items:end;animation:finFadeUp .52s ease 40ms both}.fin-field{display:grid;gap:.35rem}.fin-field label{font-weight:600;font-size:.85rem;color:#38536a;font-family:Urbanist,sans-serif}.fin-field input,.fin-field select{border:1px solid #c8d8ea;border-radius:11px;padding:.56rem .7rem;font-family:Urbanist,sans-serif;color:#2f4a5e;background:#fff}.fin-actions{display:flex;gap:.55rem;justify-content:flex-end}.btn-primary,.btn-secondary{border:none;border-radius:11px;padding:.62rem .95rem;cursor:pointer;font-family:Urbanist,sans-serif;font-size:.88rem;font-weight:700;transition:transform .15s ease,box-shadow .2s ease,background-color .2s ease}.btn-primary{color:#fff;background:linear-gradient(135deg,var(--fin-cyan),var(--fin-cyan-deep));box-shadow:0 12px 22px #16aca747}.btn-secondary{color:var(--fin-navy);background:#0d304b14}.btn-primary:hover:not(:disabled),.btn-secondary:hover:not(:disabled),.btn-danger:hover:not(:disabled){transform:translateY(-1px)}.fin-alert{padding:.85rem 1rem;color:#9a1d1d;background:#ffe9e9;border-color:#ffc8c8;font-family:Urbanist,sans-serif}.fin-toast{position:sticky;top:10px;z-index:12;padding:.75rem .95rem;border-radius:12px;border:1px solid;font-weight:600;box-shadow:0 8px 20px #0f29441f}.fin-toast-success{color:#14532d;background:#eaf8ef;border-color:#bce8cb}.fin-toast-error{color:#9a1d1d;background:#ffe9e9;border-color:#ffc8c8}.fin-toast-warning{color:#7d5a02;background:#fff6df;border-color:#f4de9b}.fin-kpis{padding:.9rem;background:#ffffffe0;display:grid;gap:.7rem;grid-template-columns:repeat(4,minmax(0,1fr));animation:finFadeUp .56s ease 70ms both}.fin-kpis article{border:1px solid rgb(13 48 75 / .1);border-radius:14px;padding:.8rem;background:var(--fin-surface)}.fin-kpis span{display:block;color:#55748f;font-size:.82rem;font-family:Urbanist,sans-serif;letter-spacing:.02em}.fin-kpis strong{display:block;margin-top:.3rem;color:var(--fin-navy);font-size:1.16rem;font-family:Archivo,sans-serif}.fin-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.fin-grid-ops{align-items:start}.fin-card{padding:1rem;background:#ffffffe6;animation:finFadeUp .62s ease both}.fin-card h3{margin:0 0 .8rem;color:var(--fin-navy);font-family:Archivo,sans-serif;font-size:1.18rem}.fin-form{display:grid;gap:.75rem}.fin-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}.fin-form-grid label{display:grid;gap:.3rem;color:#38536a;font-size:.84rem;font-weight:600;font-family:Urbanist,sans-serif}.fin-form-grid input,.fin-form-grid select{border:1px solid #c8d8ea;border-radius:10px;padding:.5rem .62rem;font-family:Urbanist,sans-serif;color:#2f4a5e}.fin-col-2{grid-column:span 2}.fin-form-actions{display:flex;justify-content:flex-end;gap:.5rem}.fin-inline-filters{display:grid;grid-template-columns:minmax(180px,1.6fr) repeat(5,minmax(120px,1fr));gap:.55rem;margin-bottom:.7rem}.fin-inline-filters input,.fin-inline-filters select{border:1px solid #c8d8ea;border-radius:10px;padding:.44rem .55rem;font-family:Urbanist,sans-serif}.fin-inline-filters-cierres{grid-template-columns:minmax(140px,180px)}.fin-table-wrap{max-height:420px;overflow:auto}.fin-card table{width:100%;border-collapse:collapse}.fin-card th,.fin-card td{border-bottom:1px solid rgb(13 48 75 / .08);padding:.8rem .72rem;font-size:.87rem;text-align:left;font-family:Urbanist,sans-serif;color:#304a5d}.fin-card th{position:sticky;top:0;background:#f2f8fd;color:var(--fin-navy);text-transform:uppercase;letter-spacing:.06em;font-size:.74rem}.fin-card tbody tr{transition:background-color .2s ease}.fin-card tbody tr:hover{background:#f6fcff}.fin-row-actions{display:flex;gap:.35rem}.fin-badge{display:inline-block;margin-right:.35rem;padding:.16rem .5rem;border-radius:999px;font-size:.72rem;font-weight:700;text-transform:uppercase}.fin-badge-registrado{color:#0a5b36;background:#e9f8f0}.fin-badge-anulado{color:#8a2020;background:#ffe8e8}.fin-badge-lock{color:#7f5300;background:#fff3d2}.fin-pagination{margin-top:.7rem;display:flex;justify-content:space-between;align-items:center;gap:.5rem;color:#38536a;font-size:.82rem;font-family:Urbanist,sans-serif}.btn-xs{padding:.35rem .5rem;font-size:.76rem}.btn-danger{border:none;border-radius:11px;padding:.62rem .95rem;cursor:pointer;font-family:Urbanist,sans-serif;font-weight:700;background:#ffe8e8;color:#9d1d1d}@keyframes finFadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 960px){.fin-filters{grid-template-columns:1fr}.fin-actions{justify-content:stretch}.fin-actions button{flex:1}.fin-kpis{grid-template-columns:1fr 1fr}.fin-grid,.fin-inline-filters,.fin-form-grid{grid-template-columns:1fr}.fin-col-2{grid-column:auto}}.op-page{--op-cyan: #2ec7c2;--op-cyan-deep: #16aca7;--op-navy: #0d304b;--op-ink-soft: #526b7c;--op-surface: #f5fbfd;min-height:100vh;background:radial-gradient(920px 560px at 3% 12%,rgb(46 199 194 / .13),transparent 64%),radial-gradient(900px 540px at 97% 88%,rgb(13 48 75 / .1),transparent 62%),linear-gradient(180deg,#f6fbff,#eef5fa 58%,#e8f0f8)}.op-shell{width:min(1320px,calc(100% - 2rem));margin:0 auto;padding:2rem 1.4rem 2.4rem;display:grid;gap:1.15rem}.op-hero,.op-tabs-nav,.op-content{border-radius:22px;border:1px solid rgb(255 255 255 / .95);box-shadow:0 22px 38px #112e4817}.op-hero{padding:clamp(1.3rem,2.8vw,2rem);background:linear-gradient(145deg,#ffffffdb,#ffffffad),linear-gradient(125deg,#2ec7c224,#2ec7c20a);animation:opFadeUp .46s ease both}.op-kicker{display:inline-flex;margin-bottom:.78rem;padding:.34rem .75rem;border-radius:999px;background:#0d304b14;color:var(--op-navy);font-family:Urbanist,sans-serif;letter-spacing:.09em;text-transform:uppercase;font-size:.73rem;font-weight:700}.op-hero h1{margin:0;color:var(--op-navy);font-family:Archivo,sans-serif;font-weight:800;font-size:clamp(1.65rem,2.8vw,2.35rem);line-height:1.15;letter-spacing:-.02em}.op-hero p{margin:.78rem 0 0;max-width:68ch;color:var(--op-ink-soft);font-family:Urbanist,sans-serif;font-size:1rem;line-height:1.56}.op-tabs-nav{padding:.8rem;background:#ffffffe6;display:flex;gap:.6rem;align-items:center;overflow-x:auto;animation:opFadeUp .52s ease 40ms both;scrollbar-width:thin}.op-tabs-nav::-webkit-scrollbar{height:6px}.op-tabs-nav::-webkit-scrollbar-track{background:transparent}.op-tabs-nav::-webkit-scrollbar-thumb{background:#16aca740;border-radius:3px}.op-tab-btn{border:none;border-radius:11px;padding:.65rem 1.1rem;background:transparent;cursor:pointer;font-family:Urbanist,sans-serif;font-size:.94rem;font-weight:700;color:var(--op-ink-soft);display:flex;align-items:center;gap:.6rem;white-space:nowrap;transition:all .2s ease}.op-tab-btn:hover:not(.op-tab-active){background:#0d304b0f;color:var(--op-navy)}.op-tab-btn.op-tab-active{color:#fff;background:linear-gradient(135deg,var(--op-cyan),var(--op-cyan-deep));box-shadow:0 8px 16px #16aca747}.op-tab-icon{font-size:1.2rem;line-height:1}.op-tab-label{font-size:.94rem;font-weight:700}.op-content{padding:2rem;background:#ffffffe6;min-height:600px;animation:opFadeUp .6s ease 60ms both;overflow-x:auto;overflow-y:auto;max-height:calc(100vh - 10rem)}.op-content::-webkit-scrollbar{width:8px}.op-content::-webkit-scrollbar-track{background:transparent}.op-content::-webkit-scrollbar-thumb{background:#16aca74d;border-radius:4px}.op-content::-webkit-scrollbar-thumb:hover{background:#16aca780}.op-content h2{margin:0 0 .9rem;color:var(--op-navy);font-family:Archivo,sans-serif;font-weight:800;font-size:clamp(1.25rem,2.5vw,1.5rem);letter-spacing:-.01em}.op-content h3{margin:.7rem 0 .5rem;color:var(--op-navy);font-family:Archivo,sans-serif;font-weight:700;font-size:1.1rem}.op-content h4{margin:.5rem 0 .35rem;color:#38536a;font-family:Urbanist,sans-serif;font-weight:700;font-size:1rem}.op-content label{display:block;color:#38536a;font-size:.84rem;font-weight:600;font-family:Urbanist,sans-serif;margin-bottom:.3rem}.op-content input,.op-content select,.op-content textarea{border:1px solid #c8d8ea;border-radius:10px;padding:.5rem .62rem;font-family:Urbanist,sans-serif;font-size:.92rem;color:#2f4a5e;background:#fff}.op-content input:focus,.op-content select:focus,.op-content textarea:focus{outline:none;border-color:var(--op-cyan);background:#fff;box-shadow:0 0 0 2.5px #2ec7c21f}.op-content button{border:none;border-radius:10px;padding:.6rem .92rem;cursor:pointer;font-family:Urbanist,sans-serif;font-size:.88rem;font-weight:700;transition:all .2s ease}.op-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-bottom:.9rem}.op-form-group{display:flex;flex-direction:column;gap:.3rem}.op-form-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.8rem}.op-table-wrap{max-height:420px;overflow:auto;border-radius:10px;background:#fff;border:1px solid rgb(13 48 75 / .08)}.op-content table{width:100%;border-collapse:collapse}.op-content th,.op-content td{border-bottom:1px solid rgb(13 48 75 / .08);padding:.85rem 1rem;font-size:.95rem;text-align:left;font-family:Urbanist,sans-serif;color:#304a5d;white-space:nowrap}.op-content th{position:sticky;top:0;background:#f2f8fd;color:var(--op-navy);font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:.72rem}.op-content tbody tr{transition:background-color .15s ease}.op-content tbody tr:hover{background:#f6fcff}.btn-edit{padding:.42rem .68rem;font-size:.8rem;background:linear-gradient(135deg,var(--op-cyan),var(--op-cyan-deep));color:#fff;box-shadow:0 6px 12px #16aca733}.btn-danger{background:#e8c8c8;color:#8a1f1f;padding:.6rem .92rem;border-radius:10px;font-weight:700;font-family:Urbanist,sans-serif}.badge{display:inline-block;padding:.22rem .52rem;border-radius:999px;font-size:.7rem;font-weight:700;text-transform:uppercase;font-family:Urbanist,sans-serif}.op-section{margin-bottom:1.2rem}.op-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.7rem;padding-bottom:.6rem;border-bottom:1px solid rgb(13 48 75 / .08);gap:.8rem}.op-section-title{color:var(--op-navy);font-family:Archivo,sans-serif;font-size:1.12rem;font-weight:800;margin:0;letter-spacing:-.005em}.op-section-actions{display:flex;gap:.5rem;flex-wrap:wrap}.op-alert{padding:.75rem .95rem;border-radius:10px;border-left:4px solid;margin-bottom:.8rem;font-family:Urbanist,sans-serif;font-size:.9rem;animation:opFadeUp .3s ease both}.op-alert-success{background:#e9f8f0;border-left-color:#10b981;color:#0a5b36}.op-alert-error{background:#ffe9e9;border-left-color:#ef4444;color:#9a1d1d}.op-alert-warning{background:#fff3d2;border-left-color:#f59e0b;color:#7d5a02}.op-alert-info{background:#dbeafe;border-left-color:#2ec7c2;color:#1e3a8a}.op-empty{text-align:center;padding:2.5rem 1rem;color:#526b7c;font-size:.95rem;background:transparent}.op-empty-icon{font-size:2.8rem;margin-bottom:.6rem;opacity:.5}.op-loading{text-align:center;padding:1.5rem;color:#526b7c;font-size:.9rem;animation:opPulse 2s ease-in-out infinite}@keyframes opFadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 960px){.op-shell{padding:1.5rem 1rem 2rem;gap:1rem}.op-tabs-nav{gap:.4rem;padding:.7rem}.op-tab-btn{padding:.6rem .95rem;font-size:.88rem}.op-form-grid{grid-template-columns:1fr;gap:.5rem}.op-content{min-height:auto;padding:1rem}}@media (max-width: 600px){.op-shell{padding:1rem .8rem 1.5rem;gap:.8rem}.op-hero{padding:clamp(1rem,2vw,1.3rem)}.op-hero h1{font-size:clamp(1.3rem,2.2vw,1.6rem);margin-bottom:.4rem}.op-hero p{font-size:.9rem;margin-top:.5rem}.op-kicker{margin-bottom:.5rem;font-size:.65rem;padding:.3rem .6rem}.op-tabs-nav{gap:.3rem;padding:.6rem}.op-tab-btn{padding:.55rem .85rem;font-size:.82rem;gap:.4rem}.op-tab-icon{font-size:1.1rem}.op-content{padding:.9rem;border-radius:16px;max-height:calc(100vh - 14rem)}.op-content h2{font-size:1.15rem;margin-bottom:.7rem}.op-content th,.op-content td{padding:.45rem .5rem;font-size:.78rem}.op-content th{font-size:.68rem}.btn-primary,.btn-secondary,.btn-danger{padding:.52rem .8rem;font-size:.82rem}.badge{padding:.2rem .45rem;font-size:.65rem}.op-form-grid{grid-template-columns:1fr;gap:.45rem}.op-form-actions{gap:.4rem;margin-top:.6rem}.op-section-title{font-size:1rem}.op-alert{padding:.65rem .8rem;font-size:.82rem;margin-bottom:.6rem}}:root{--op-cyan: #2ec7c2;--op-cyan-deep: #16aca7;--op-navy: #0d304b;--op-ink-soft: #526b7c;--op-surface: #f5fbfd}.tab-section{margin-bottom:2rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.8rem;border-bottom:1px solid rgb(13 48 75 / .08);gap:.9rem}.section-header h2{margin:0;color:var(--op-navy);font-family:Archivo,sans-serif;font-size:1.15rem;font-weight:800;letter-spacing:-.01em}.section-header h3{margin:0;color:#38536a;font-family:Archivo,sans-serif;font-size:1.05rem;font-weight:700}.section-header h4{margin:0;color:#38536a;font-family:Urbanist,sans-serif;font-size:1rem;font-weight:700}.header-actions{display:flex;gap:.6rem;align-items:center}.header-actions .btn-primary{white-space:nowrap}.form-container{background:#ffffffe6;padding:1.2rem;border-radius:11px;margin-bottom:1.2rem;border:1px solid rgb(13 48 75 / .08)}.form-group{margin-bottom:1.3rem;display:flex;flex-direction:column;gap:.6rem}.form-group label{font-family:Urbanist,sans-serif;font-weight:600;color:#38536a;font-size:.84rem}.form-group input,.form-group select,.form-group textarea{padding:.5rem .62rem;border:1px solid #c8d8ea;border-radius:10px;font-family:Urbanist,sans-serif;font-size:.92rem;color:#2f4a5e;background:#fff;transition:all .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--op-cyan);box-shadow:0 0 0 2.5px #2ec7c21f;background:#fff}.form-group input::placeholder,.form-group select::placeholder,.form-group textarea::placeholder{color:#6b728099}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background:#f9fafbcc;color:#6b728099;cursor:not-allowed}.form-group textarea{resize:vertical;min-height:80px;line-height:1.4}.form-group select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%230d304b'%3E%3Cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z' clip-rule='evenodd'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center;background-size:1.2rem;padding-right:2.2rem;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem;margin-bottom:1rem}.form-actions{display:flex;gap:.5rem;justify-content:flex-end;flex-wrap:wrap;margin-top:.7rem}.table-container{overflow-x:auto;border-radius:10px;background:#fff;border:1px solid rgb(13 48 75 / .08);margin-bottom:1.2rem;max-height:600px}.table-container::-webkit-scrollbar{height:12px;width:12px}.table-container::-webkit-scrollbar-track{background:#0d304b0d;border-radius:10px}.table-container::-webkit-scrollbar-thumb{background:var(--op-cyan);border-radius:10px;border:2px solid rgb(13 48 75 / .05)}.table-container::-webkit-scrollbar-thumb:hover{background:var(--op-cyan-deep)}.data-table{width:100%;border-collapse:collapse;font-family:Urbanist,sans-serif;font-size:.87rem}.data-table thead{background:#f2f8fd;color:var(--op-navy);position:sticky;top:0}.data-table thead th{padding:.95rem 1.2rem;text-align:left;font-weight:700;font-family:Urbanist,sans-serif;letter-spacing:.05em;font-size:.75rem;text-transform:uppercase;color:var(--op-navy)}.data-table tbody tr{border-bottom:1px solid rgb(13 48 75 / .08);transition:background-color .15s ease}.data-table tbody tr:hover{background-color:#f6fcff}.data-table tbody td{padding:.9rem 1rem;vertical-align:middle;font-size:.95rem;color:#304a5d;min-width:120px}.data-table.small thead th,.data-table.small tbody td{padding:.45rem .5rem;font-size:.78rem}.text-right{text-align:right}.text-left{text-align:left}.text-code{font-family:Courier New,monospace;font-weight:600;color:#06c;background:#0066cc14;padding:.2rem .4rem;border-radius:4px}.text-small{font-size:.8rem;color:#526b7c}.text-muted{color:#6b7280b3}.badge{display:inline-block;padding:.22rem .52rem;border-radius:999px;font-size:.7rem;font-weight:700;text-transform:uppercase;font-family:Urbanist,sans-serif;line-height:1}.badge-success{color:#0a5b36;background:#e9f8f0}.badge-danger{color:#8a2020;background:#ffe8e8}.badge-warning{color:#7d5a02;background:#fff3d2}.badge-info{color:#1e3a8a;background:#dbeafe}.badge-secondary{color:#374151;background:#e5e7eb}.badge-primary{color:#fff;background:linear-gradient(135deg,var(--op-cyan),var(--op-cyan-deep))}.btn-primary,.btn-secondary,.btn-danger,.btn-info,.btn-small,.btn-edit{border:none;border-radius:10px;padding:.6rem .92rem;cursor:pointer;font-family:Urbanist,sans-serif;font-size:.88rem;font-weight:700;transition:all .2s ease;letter-spacing:.3px;text-transform:capitalize;display:inline-flex;align-items:center;gap:.4rem;outline:none}.btn-primary{background:linear-gradient(135deg,var(--op-cyan),var(--op-cyan-deep));color:#fff;box-shadow:0 8px 16px #16aca73d}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 20px #16aca752}.btn-secondary{background:#0d304b14;color:var(--op-navy)}.btn-secondary:hover:not(:disabled){background:#0d304b1f;transform:translateY(-1px)}.btn-danger{background:#e8c8c8;color:#8a1f1f;box-shadow:0 4px 8px #ef444426}.btn-danger:hover:not(:disabled){background:#e8b8b8;transform:translateY(-1px)}.btn-info{background:linear-gradient(135deg,#06c,#004999);color:#fff;box-shadow:0 8px 16px #0066cc3d}.btn-info:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 20px #0066cc52}.btn-small{padding:.4rem .65rem;font-size:.8rem;border-radius:8px}.btn-edit{padding:.42rem .68rem;font-size:.8rem;border-radius:8px;background:linear-gradient(135deg,var(--op-cyan),var(--op-cyan-deep));color:#fff;box-shadow:0 6px 12px #16aca733}.btn-edit:hover:not(:disabled){transform:translateY(-.5px)}.btn-primary:disabled,.btn-secondary:disabled,.btn-danger:disabled,.btn-info:disabled{opacity:.5;cursor:not-allowed;transform:none}.filters-container{display:flex;gap:.55rem;margin-bottom:.9rem;flex-wrap:wrap;align-items:center}.filters-container input,.filters-container select{min-width:160px;padding:.5rem .62rem;border:1px solid #c8d8ea;border-radius:10px;font-family:Urbanist,sans-serif;font-size:.92rem;background:#fff;transition:all .2s ease}.filters-container input:focus,.filters-container select:focus{outline:none;border-color:var(--op-cyan);box-shadow:0 0 0 2.5px #2ec7c21f}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:opFadeUp .3s ease-out both}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000040;max-width:500px;width:100%;max-height:85vh;overflow-y:auto;animation:opSlideUp .3s ease-out both}.modal-content.modal-large{max-width:650px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid rgb(13 48 75 / .08)}.modal-header h3{margin:0;font-family:Archivo,sans-serif;font-size:1.2rem;font-weight:700;color:var(--op-navy)}.modal-body{padding:1rem}.modal-actions{display:flex;gap:.6rem;justify-content:flex-end;padding:1.1rem 1.2rem;border-top:1px solid rgb(13 48 75 / .08);background:#f9fafb80}.modal-close{background:none;border:none;font-size:1.4rem;cursor:pointer;color:#526b7c;padding:0;line-height:1;transition:color .2s ease}.modal-close:hover{color:var(--op-navy)}.alert{padding:.75rem .95rem;border-radius:10px;margin-bottom:.8rem;border-left:4px solid;display:flex;align-items:flex-start;gap:.65rem;font-family:Urbanist,sans-serif;font-size:.9rem;animation:opFadeUp .3s ease-out both}.alert-success{background:#e9f8f0;color:#0a5b36;border-left-color:#10b981}.alert-danger{background:#ffe9e9;color:#9a1d1d;border-left-color:#ef4444}.alert-warning{background:#fff3d2;color:#7d5a02;border-left-color:#f59e0b}.alert-info{background:#dbeafe;color:#1e3a8a;border-left-color:#2ec7c2}.details-panel{background:#f6fafb;padding:1.1rem;border-radius:10px;margin:1rem 0;border-left:4px solid var(--op-cyan);border:1px solid rgb(13 48 75 / .08)}.details-panel dt{font-weight:700;color:var(--op-navy);margin-top:.5rem;font-size:.85rem;font-family:Urbanist,sans-serif}.details-panel dd{margin-left:0;margin-bottom:.5rem;color:#38536a;font-family:Urbanist,sans-serif;font-size:.88rem}.add-item-section,.add-price-section{background:#0066cc0a;padding:1.1rem;border-radius:10px;margin-bottom:1rem;border:1px solid rgb(46 199 194 / .2);animation:opFadeUp .3s ease-out both}.add-item-section h4,.add-price-section h4{margin:0 0 .7rem;color:var(--op-navy);font-family:Archivo,sans-serif;font-size:1rem;font-weight:700}.items-section{margin:1rem 0}.items-section h4{margin:0 0 .7rem;color:var(--op-navy);font-family:Archivo,sans-serif;font-size:1rem;font-weight:700}.item-row{background:#fff;padding:.75rem;border-radius:10px;margin-bottom:.6rem;border:1px solid rgb(13 48 75 / .08);display:flex;justify-content:space-between;align-items:center;transition:all .15s ease}.item-row:hover{box-shadow:0 4px 8px #112e4814;transform:translateY(-1px)}.item-row-info{flex:1}.item-row-actions{display:flex;gap:.35rem;margin-left:.8rem}.actions-section{background:#0066cc0a;padding:.9rem;border-radius:10px;display:flex;gap:.6rem;flex-wrap:wrap;border:1px solid rgb(46 199 194 / .2)}.precios-list{margin-top:1rem;padding-top:.9rem;border-top:1px solid rgb(13 48 75 / .08)}.precios-list h4{margin:0 0 .7rem;color:var(--op-navy);font-family:Archivo,sans-serif;font-weight:700}.loading{text-align:center;padding:1.5rem;color:#526b7c;font-size:.9rem;animation:opPulse 2s ease-in-out infinite}.empty{text-align:center;padding:2rem 1rem;color:#526b7c;font-size:.95rem;background:transparent}@keyframes opFadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes opSlideUp{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.pagination-container{display:flex;justify-content:space-between;align-items:center;padding:1.2rem;background:#2ec7c208;border:1px solid rgb(46 199 194 / .15);border-top:none;border-radius:0 0 10px 10px;gap:2rem;flex-wrap:wrap;margin-bottom:1.2rem}.pagination-info{display:flex;align-items:center;gap:.5rem;color:var(--op-ink-soft);font-family:Urbanist,sans-serif;font-size:.9rem;font-weight:500}.pagination-controls{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}.pagination-size-selector{padding:.5rem .8rem;border:1px solid rgb(46 199 194 / .3);border-radius:6px;background:#fff;color:var(--op-navy);font-family:Urbanist,sans-serif;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease-out}.pagination-size-selector:hover:not(:disabled){border-color:var(--op-cyan);background:#2ec7c20d}.pagination-buttons{display:flex;align-items:center;gap:.8rem}.page-indicator{color:var(--op-navy);font-family:Urbanist,sans-serif;font-size:.85rem;font-weight:600;min-width:140px;text-align:center}.btn-pagination{padding:.5rem 1rem;border:1px solid rgb(46 199 194 / .3);border-radius:6px;background:#fff;color:var(--op-cyan-deep);font-family:Urbanist,sans-serif;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease-out}.btn-pagination:hover:not(:disabled){background:var(--op-cyan);color:#fff;border-color:var(--op-cyan);transform:translateY(-1px)}.btn-pagination:disabled{opacity:.4;cursor:not-allowed}@keyframes opPulse{0%,to{opacity:1}50%{opacity:.7}}@media (max-width: 960px){.form-row{grid-template-columns:1fr;gap:.5rem}.filters-container{flex-direction:column}.filters-container input,.filters-container select{width:100%;min-width:auto}.form-actions{flex-direction:column}.form-actions button{width:100%}.item-row{flex-direction:column;align-items:flex-start}.item-row-actions{width:100%;margin-top:.6rem;margin-left:0}.actions-section{flex-direction:column}.actions-section button{width:100%}}@media (max-width: 600px){.form-row{grid-template-columns:1fr;gap:.45rem}.form-actions{gap:.4rem;margin-top:.6rem}.btn-primary,.btn-secondary,.btn-danger,.btn-info{padding:.52rem .8rem;font-size:.82rem}.badge{padding:.2rem .45rem;font-size:.65rem}.data-table th{font-size:.65rem;padding:.45rem .4rem}.data-table td{font-size:.78rem;padding:.45rem .4rem}.modal-content{max-width:90vw;border-radius:10px}.modal-header,.modal-body,.modal-actions{padding:.8rem}.modal-header h3{font-size:1.05rem}.alert{padding:.65rem .8rem;font-size:.82rem;margin-bottom:.6rem}.section-header h2{font-size:1rem}.item-row{padding:.65rem;margin-bottom:.5rem}}.solped-document{background:#fff;padding:40px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:#2c3e50;print-color-adjust:exact;-webkit-print-color-adjust:exact;line-height:1.6;max-width:1100px;margin:0 auto}.solped-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px;padding-bottom:20px;border-bottom:3px solid #2c3e50}.company-info h1{font-size:28px;font-weight:700;color:#2c3e50;margin:0 0 5px;letter-spacing:1px}.company-info p{font-size:13px;color:#3498db;margin:0;font-weight:500}.header-right{text-align:right;display:flex;flex-direction:column;gap:15px;align-items:flex-end}.estado-badge{display:inline-block;padding:8px 16px;border-radius:6px;font-weight:700;font-size:12px;letter-spacing:.8px;text-transform:uppercase}.badge-draft{background:#ecf0f1;color:#7f8c8d;border:1px solid #bdc3c7}.badge-sent{background:#3498db;color:#fff;border:1px solid #2980b9}.badge-approved{background:#27ae60;color:#fff;border:1px solid #229954}.badge-rejected{background:#e74c3c;color:#fff;border:1px solid #c0392b}.badge-default{background:#ecf0f1;color:#2c3e50;border:1px solid #bdc3c7}.numero-solped{display:flex;align-items:baseline;gap:10px;padding:10px 15px;background:#f8f9fa;border-radius:4px;border-left:4px solid #3498db}.numero-solped .label{font-size:12px;color:#7f8c8d;text-transform:uppercase;font-weight:600}.numero-solped .valor{font-size:18px;font-weight:700;color:#2c3e50;font-family:Courier New,monospace}.solped-content{display:grid;grid-template-columns:2fr 1fr;gap:30px;margin-bottom:30px}.solped-info{display:flex;flex-direction:column;gap:20px}.info-section{background:#f8f9fa;padding:20px;border-radius:6px;border-left:4px solid #3498db}.info-section--approved{border-left-color:#27ae60}.info-section--rejected{border-left-color:#e74c3c;background:#fff5f5}.section-title{margin:0 0 15px;font-size:13px;font-weight:700;color:#2c3e50;text-transform:uppercase;letter-spacing:.5px;padding-bottom:10px;border-bottom:1px solid #e0e6ed}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px}.info-item{display:flex;flex-direction:column}.info-item label{font-size:11px;font-weight:600;color:#7f8c8d;text-transform:uppercase;margin-bottom:4px;letter-spacing:.3px}.info-item p{margin:0;font-size:14px;color:#2c3e50;font-weight:500}.observaciones{background:#fff;padding:10px;border-radius:3px;border-left:2px solid #f39c12;font-style:italic;font-size:13px;color:#555}.observaciones--rejected{border-left-color:#e74c3c;color:#c0392b}.solped-summary{display:flex;flex-direction:column}.summary-card{background:linear-gradient(135deg,#1a2a3a,#2c3e50);border-radius:8px;padding:25px;color:#fff;display:flex;flex-direction:column;gap:20px;box-shadow:0 4px 12px #00000026;height:100%}.summary-item{display:flex;justify-content:space-between;align-items:center;padding-bottom:15px;border-bottom:1px solid rgba(255,255,255,.15)}.summary-item:last-child{border-bottom:none;padding-bottom:0}.summary-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;opacity:.75}.summary-value{font-size:20px;font-weight:700;color:#5dade2}.summary-estado-pill{display:inline-block;padding:5px 12px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;background:#ffffff2e;color:#fff;border:1px solid rgba(255,255,255,.35)}.solped-items{margin-bottom:30px}.table-wrapper{overflow-x:auto;border-radius:6px;box-shadow:0 2px 6px #00000012}.items-table{width:100%;border-collapse:collapse;font-size:13px}.items-table thead{background:#2c3e50;color:#fff}.items-table thead th{padding:13px 15px;text-align:left;font-weight:600;text-transform:uppercase;letter-spacing:.3px;font-size:11px;white-space:nowrap}.items-table tbody td{padding:11px 15px;border-bottom:1px solid #ecf0f1;background:#fff;vertical-align:middle}.items-table tbody tr:nth-child(odd) td{background:#f8f9fa}.items-table tbody tr:hover td{background:#eaf4fb;transition:background .15s ease}.tfoot-total td{padding:14px 15px;border-top:2px solid #2c3e50;background:#ecf0f1;font-size:13px;color:#2c3e50}.total-cell{background:#2980b9!important;color:#fff!important;font-size:14px;font-weight:700}.col-codigo{width:90px;font-family:Courier New,monospace;font-weight:600;color:#2980b9}.col-material{min-width:180px}.col-cant{width:80px}.col-unidad{width:70px}.col-proveedor{width:160px}.col-precio{width:100px}.col-subtotal{width:110px}.text-right{text-align:right!important}.text-center{text-align:center!important}.font-bold{font-weight:700!important}.solped-footer{text-align:center;padding-top:20px;margin-top:30px;border-top:1px solid #ecf0f1}.footer-text{font-size:11px;color:#95a5a6;margin:0}.error-message{text-align:center;color:#e74c3c;font-weight:600;padding:30px}@media print{.solped-document{padding:20px;background:#fff;max-width:100%}.solped-header{page-break-after:avoid}.solped-content,.items-table,.items-table tbody tr{page-break-inside:avoid}.items-table thead,.items-table thead th,.tfoot-total td,.total-cell,.summary-card,.estado-badge{print-color-adjust:exact;-webkit-print-color-adjust:exact}@page{size:A4 landscape;margin:15mm}}@media (max-width: 1024px){.solped-content{grid-template-columns:1fr}.summary-card{flex-direction:row;flex-wrap:wrap;gap:15px}.summary-item{flex:1 1 120px;flex-direction:column;border-bottom:none;padding-bottom:0;text-align:center;gap:6px}}@media (max-width: 768px){.solped-document{padding:20px}.solped-header{flex-direction:column;gap:15px}.header-right{width:100%;align-items:flex-start}.info-grid{grid-template-columns:1fr}.items-table{font-size:12px}.items-table thead th,.items-table tbody td,.tfoot-total td{padding:9px 8px}}.briefs-page{--brief-cyan: #2ec7c2;--brief-cyan-deep: #16aca7;--brief-navy: #0d304b;--brief-ink-soft: #546d7e;--brief-bg-card: rgb(255 255 255 / .88);--brief-surface: #f5fbfd;min-height:100vh;background:radial-gradient(940px 560px at 6% 8%,rgb(46 199 194 / .13),transparent 62%),radial-gradient(900px 520px at 95% 92%,rgb(13 48 75 / .11),transparent 62%),linear-gradient(180deg,#f6fbff,#edf4fb 58%,#e8f0f8);display:flex;flex-direction:column}.briefs-main{flex:1;width:min(1320px,calc(100% - 2rem));margin:0 auto;padding:2rem 0 2.4rem;display:grid;gap:1.15rem}.briefs-hero{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(300px,.95fr);gap:1.1rem}.briefs-hero-copy,.briefs-hero-summary{border-radius:22px;border:1px solid rgb(255 255 255 / .95);box-shadow:0 22px 38px #112e4817}.briefs-hero-copy{padding:clamp(1.3rem,2.8vw,2rem);background:linear-gradient(145deg,#ffffffdb,#ffffffad),linear-gradient(125deg,#2ec7c226,#2ec7c20a);animation:briefs-fadeUp .42s ease both}.briefs-kicker{display:inline-flex;margin-bottom:.82rem;padding:.34rem .75rem;border-radius:999px;background:#0d304b14;color:var(--brief-navy);font-family:Urbanist,sans-serif;letter-spacing:.09em;text-transform:uppercase;font-size:.73rem;font-weight:700}.briefs-hero-copy h1{margin:0;font-family:Archivo,sans-serif;font-weight:800;font-size:clamp(1.65rem,2.8vw,2.35rem);line-height:1.15;letter-spacing:-.02em;color:var(--brief-navy)}.briefs-hero-copy p{margin:.75rem 0 0;max-width:64ch;font-family:Urbanist,sans-serif;color:var(--brief-ink-soft);font-size:1rem;line-height:1.56}.briefs-hero-pills{margin-top:.95rem;display:flex;flex-wrap:wrap;gap:.48rem}.briefs-hero-pills span{border-radius:999px;padding:.36rem .72rem;background:#0d304b1a;color:var(--brief-navy);font-family:Urbanist,sans-serif;font-size:.78rem;font-weight:700}.briefs-hero-summary{padding:1.2rem;background:linear-gradient(145deg,#0d304bf5,#134162eb);color:#fff;display:grid;align-content:start;gap:.72rem;animation:briefs-fadeUp .52s ease 70ms both}.briefs-summary-item{border-radius:12px;border:1px solid rgb(255 255 255 / .16);background:#ffffff14;padding:.82rem;display:grid;gap:.28rem}.briefs-summary-item span{font-family:Urbanist,sans-serif;font-size:.78rem;color:#f0f9ffd1}.briefs-summary-item strong{font-family:Archivo,sans-serif;font-size:1.12rem;line-height:1.1;color:#fff}.briefs-create-btn{color:#fff;background:linear-gradient(135deg,var(--brief-cyan),var(--brief-cyan-deep));box-shadow:0 12px 22px #16aca74d;width:100%;margin-top:.2rem}.briefs-create-btn:hover{transform:translateY(-2px)}.briefs-filters-card{border-radius:22px;border:1px solid rgb(255 255 255 / .95);background:var(--brief-bg-card);box-shadow:0 22px 38px #112e4817;animation:briefs-fadeUp .48s ease both}.briefs-card-header{padding:clamp(1.3rem,2.8vw,2rem);border-bottom:1px solid rgb(0 0 0 / .08)}.briefs-card-header h2{margin:0;font-family:Archivo,sans-serif;font-size:1.24rem;font-weight:700;color:var(--brief-navy)}.briefs-card-header p{margin:.34rem 0 0;color:var(--brief-ink-soft);font-family:Urbanist,sans-serif;font-size:.86rem}.brief-filters{display:flex;flex-direction:column;gap:1.2rem;padding:clamp(1.3rem,2.8vw,2rem)}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.filter-group{display:flex;flex-direction:column;gap:.42rem}.filter-group label{font-family:Urbanist,sans-serif;font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--brief-navy)}.filter-input,.filter-select{width:100%;border-radius:11px;border:1px solid rgb(13 48 75 / .18);background:#fff;padding:.64rem .75rem;font-family:Urbanist,sans-serif;font-size:.87rem;color:var(--brief-navy);transition:border-color .2s ease,box-shadow .2s ease}.filter-input:focus,.filter-select:focus{outline:none;border-color:var(--brief-cyan-deep);box-shadow:0 0 0 3px #2ec7c22e;background:#fafbff}.filter-input::placeholder{color:#999}.filter-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23546d7e' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2rem}.filters-actions{display:flex;gap:.75rem}.briefs-table-section{border-radius:22px;border:1px solid rgb(255 255 255 / .95);background:var(--brief-bg-card);box-shadow:0 22px 38px #112e4817;overflow:hidden;animation:briefs-fadeUp .52s ease 70ms both}.brief-table-wrapper{overflow-x:auto}.brief-table{width:100%;border-collapse:collapse;background:#fff}.brief-table thead{background-color:#f0f2f5;border-bottom:2px solid #e0e0e0}.brief-table thead th{padding:1rem;text-align:left;font-family:Urbanist,sans-serif;font-weight:600;font-size:.8rem;color:var(--brief-navy);text-transform:uppercase;letter-spacing:.5px}.brief-table tbody tr{border-bottom:1px solid #f0f0f0;transition:background-color .2s ease;cursor:pointer}.brief-table tbody tr:hover{background-color:#2ec7c20d}.brief-table tbody tr:last-child{border-bottom:none}.brief-table tbody td{padding:1rem;font-family:Urbanist,sans-serif;font-size:.95rem;color:var(--brief-ink-soft)}.brief-table tbody td strong{color:var(--brief-navy);font-weight:600}.brief-table .numero-brief{font-family:Archivo,sans-serif;font-weight:700;color:var(--brief-cyan);font-size:1rem;letter-spacing:-.01em}.brief-table .cliente{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.brief-table .producto{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge{display:inline-flex;align-items:center;justify-content:center;border-radius:8px;padding:.32rem .72rem;font-family:Urbanist,sans-serif;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.badge-success{background:#22c55e2e;color:#166534}.badge-primary{background:#3b82f62e;color:#1e40af}.badge-warning{background:#fb923c2e;color:#92400e}.badge-danger{background:#ef44442e;color:#7f1d1d}.badge-info{background:#2ec7c22e;color:var(--brief-navy)}.badge-secondary{background:#6b72802e;color:#374151}.editing-indicator{display:inline-flex;align-items:center;justify-content:center;border-radius:6px;padding:.32rem .64rem;font-family:Urbanist,sans-serif;font-size:.75rem;font-weight:700;letter-spacing:.03em;background:#dbeafecc;color:#1e40af}.editing-success{background:#dcfce7cc;color:#166534}.editing-warning{background:#fef3c7cc;color:#92400e}.editing-danger{background:#fee2e2cc;color:#7f1d1d}.loading-state{min-height:240px;display:grid;place-items:center;text-align:center;gap:.75rem;font-family:Urbanist,sans-serif;color:var(--brief-ink-soft)}.loading-spinner{width:46px;height:46px;border:4px solid rgb(46 199 194 / .2);border-top-color:var(--brief-cyan-deep);border-radius:50%;animation:briefs-spin .9s linear infinite}.empty-state{min-height:280px;display:grid;place-items:center;text-align:center;padding:2rem;font-family:Urbanist,sans-serif;color:var(--brief-ink-soft)}.empty-state p{margin:0;max-width:48ch}.pagination-controls{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1.2rem;flex-wrap:wrap}.pagination-info{font-family:Urbanist,sans-serif;font-size:.9rem;color:var(--brief-ink-soft)}.btn{border:none;border-radius:11px;min-height:40px;padding:.56rem .92rem;font-family:Urbanist,sans-serif;font-size:.84rem;font-weight:700;cursor:pointer;transition:transform .16s ease,box-shadow .2s ease,filter .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn:hover,.btn:focus-visible{transform:translateY(-1px)}.btn-primary.is-open{background:linear-gradient(135deg,#3e6e92,#274b68);box-shadow:0 12px 22px #274b6847}.btn-secondary{color:#fff;background:linear-gradient(135deg,#4f6d87,#35506a);box-shadow:0 12px 20px #35506a38}.btn-secondary:hover{background:linear-gradient(135deg,#5a7894,#3f5a76)}.btn-lg{padding:.68rem 1.2rem;min-height:44px;font-size:.88rem}.btn-sm{padding:.48rem .75rem;min-height:36px;font-size:.78rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0d304b73;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:briefs-fadeIn .24s ease both}.modal-content{position:relative;max-height:90vh;max-width:600px;width:90%;background:#fff;border-radius:20px;box-shadow:0 25px 50px #0d304b26;overflow:auto;animation:briefs-slideUp .36s cubic-bezier(.34,1.56,.64,1) both}.modal-header{padding:1.5rem;border-bottom:1px solid rgb(0 0 0 / .08);display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;font-family:Archivo,sans-serif;font-weight:700;font-size:1.28rem;color:var(--brief-navy)}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#999;transition:color .2s ease;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.modal-close:hover{color:var(--brief-navy)}.modal-body{padding:1.5rem}.modal-footer{padding:1.2rem 1.5rem;border-top:1px solid rgb(0 0 0 / .08);display:flex;justify-content:flex-end;gap:.8rem}.form-group{display:grid;gap:.42rem;margin-bottom:1.2rem}.form-label{font-family:Urbanist,sans-serif;font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--brief-navy)}.form-input,.form-select,.form-textarea{width:100%;border-radius:11px;border:1px solid rgb(13 48 75 / .18);background:#fff;padding:.75rem;font-family:Urbanist,sans-serif;font-size:.9rem;color:var(--brief-navy);transition:border-color .2s ease,box-shadow .2s ease}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--brief-cyan-deep);box-shadow:0 0 0 3px #2ec7c22e}.form-textarea{resize:vertical;min-height:100px;font-family:Urbanist,sans-serif}.step-section{display:grid;gap:1.5rem}.step-header{display:flex;align-items:center;gap:.8rem;padding-bottom:1rem;border-bottom:2px solid rgb(46,199,194,.2);margin-bottom:1rem}.step-number{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--brief-cyan),var(--brief-cyan-deep));color:#fff;font-weight:700;font-size:.9rem}.step-title{margin:0;font-family:Archivo,sans-serif;font-weight:700;font-size:1.1rem;color:var(--brief-navy)}.checkbox-group{display:flex;flex-direction:column;gap:.8rem}.checkbox-item{display:flex;align-items:center;gap:.6rem}.checkbox-item input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--brief-cyan)}.checkbox-item label{margin:0;font-family:Urbanist,sans-serif;font-size:.9rem;color:var(--brief-navy);cursor:pointer}@keyframes briefs-fadeIn{0%{opacity:0}to{opacity:1}}@keyframes briefs-fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes briefs-slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes briefs-spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.briefs-main{gap:1rem;padding:1.2rem 0 1.8rem}.briefs-hero{grid-template-columns:1fr;gap:.8rem}.briefs-hero-copy,.briefs-hero-summary{padding:1.2rem}.briefs-hero-copy h1{font-size:1.5rem}.filters-grid,.form-row{grid-template-columns:1fr}.brief-table{font-size:.85rem}.brief-table thead th,.brief-table tbody td{padding:.75rem .5rem}.modal-content{width:95%;max-height:none}}.comparison-section{margin-top:1.2rem;padding:1rem;background:#f0f9ff80;border-radius:12px;border:1px solid rgb(46,199,194,.2)}.comparison-field{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid rgb(46,199,194,.1)}.comparison-field:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.comparison-field-name{font-family:Urbanist,sans-serif;font-size:.78rem;font-weight:600;text-transform:uppercase;color:var(--brief-navy);margin-bottom:.5rem;letter-spacing:.03em}.comparison-values{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;font-family:Urbanist,sans-serif;font-size:.9rem}.comparison-old{padding:.64rem;background:#fff9;border-left:3px solid #ccc;border-radius:4px;color:#666}.comparison-new{padding:.64rem;background:#2ec7c214;border-left:3px solid var(--brief-cyan);border-radius:4px;color:var(--brief-navy);font-weight:500}.edit-section-block{margin-bottom:1.5rem;padding:1.2rem;background:#f5fbfdcc;border-radius:12px;border:1px solid rgb(46,199,194,.15)}.edit-section-title{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem;padding-bottom:.8rem;border-bottom:2px solid rgb(46,199,194,.3);font-family:Archivo,sans-serif;font-weight:700;font-size:1rem;color:var(--brief-navy)}.edit-section-title:before{content:"■";color:var(--brief-cyan);font-size:.8rem}.form-section-title{margin:1.5rem 0 1rem;padding-bottom:.8rem;border-bottom:2px solid rgb(46,199,194,.3);font-family:Archivo,sans-serif;font-weight:700;font-size:1rem;color:var(--brief-navy)}.edit-form-grid{display:grid;gap:1rem}.edit-form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.edit-form-row.full{grid-template-columns:1fr}.form-label{display:block;font-size:.9rem;font-weight:600;color:var(--brief-navy);margin-bottom:.5rem}.form-label.required:after{content:" *";color:#c62828}.form-input,.form-select,.form-textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:.95rem;font-family:inherit;transition:all .2s ease;background:#fff;box-sizing:border-box}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--brief-cyan);box-shadow:0 0 0 3px #2ec7c21a;background:#fafbff}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2rem}.form-textarea{resize:vertical;min-height:100px;font-family:inherit}.form-input::placeholder,.form-textarea::placeholder{color:#999}.form-help{font-size:.8rem;color:#999;margin-top:.35rem}.form-error{color:#c62828;font-size:.85rem;margin-top:.4rem}.form-input.error,.form-select.error,.form-textarea.error{border-color:#c62828;background:#ffebee}.alert{padding:1rem;border-radius:6px;margin-bottom:1rem;border-left:4px solid;font-size:.9rem}.alert-info{background:#e3f2fd;border-left-color:var(--brief-cyan);color:var(--brief-cyan)}.alert-warning{background:#fff3e0;border-left-color:#f57c00;color:#f57c00}.alert-error{background:#ffebee;border-left-color:#c62828;color:#c62828}.alert-success{background:#e8f5e9;border-left-color:#388e3c;color:#388e3c}.btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:inherit}.btn-primary{background:linear-gradient(135deg,var(--brief-cyan),var(--brief-cyan-deep));color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 16px #16aca73d}.btn-secondary{background-color:#f0f0f0;color:var(--brief-navy);border:1px solid #ddd}.btn-secondary:hover:not(:disabled){background-color:#e6e6e6;border-color:#bbb}.btn-success{background-color:#4caf50;color:#fff}.btn-success:hover:not(:disabled){background-color:#45a049}.btn-outline{background-color:transparent;color:var(--brief-cyan);border:2px solid var(--brief-cyan)}.btn-outline:hover:not(:disabled){background-color:#2ec7c21a}.btn-sm{padding:.5rem 1rem;font-size:.85rem}.btn-lg{padding:1rem 2rem;font-size:1rem}.btn-full{width:100%}.brief-sidebar{background:#fff;border-radius:12px;padding:1.5rem;border:1px solid #e0e0e0}.sidebar-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #eee}.sidebar-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.sidebar-label{font-size:.75rem;font-weight:700;color:var(--brief-navy);text-transform:uppercase;letter-spacing:.3px;margin-bottom:.5rem}.sidebar-value{font-size:1rem;color:var(--brief-navy);font-weight:600}.confirmacion-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:2000;animation:briefs-fadeIn .3s ease}.confirmacion-content{background:#fff;border-radius:12px;padding:2rem;max-width:500px;width:90%;box-shadow:0 10px 40px #0003;animation:briefs-slideUp .4s ease;text-align:center}.confirmacion-icon{font-size:3rem;margin-bottom:1rem;animation:briefs-iconBounce .6s ease}@keyframes briefs-iconBounce{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.confirmacion-header{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e3f2fd}.confirmacion-header h2{margin:0;font-size:1.3rem;font-weight:700;color:var(--brief-navy)}.confirmacion-body{margin:1.5rem 0;color:var(--brief-ink-soft);font-size:.95rem;line-height:1.5}.confirmacion-details{background:#fafbff;border:1px solid #e0e7ff;border-radius:8px;padding:1rem;margin:1rem 0}.confirmacion-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:1.5rem}.filter-tag{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .75rem;background:#2ec7c21a;border:1px solid rgba(46,199,194,.3);border-radius:20px;font-size:.85rem;color:var(--brief-cyan-deep);font-weight:500}.filter-tag-remove{background:none;border:none;color:var(--brief-cyan-deep);cursor:pointer;font-size:1rem;padding:0;line-height:1}.modal-editar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0d304b73;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem;animation:briefs-fadeIn .24s ease both}.modal-editar-content{position:relative;background:#fff;border-radius:22px;border:1px solid rgb(255 255 255 / .95);box-shadow:0 25px 50px #0d304b26;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;animation:briefs-slideUp .36s cubic-bezier(.34,1.56,.64,1) both}.modal-editar-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem;border-bottom:1px solid rgb(0 0 0 / .08);background:#f5fbfd80}.modal-editar-header h2{margin:0;font-family:Archivo,sans-serif;font-weight:700;font-size:1.28rem;color:var(--brief-navy);letter-spacing:-.01em}.modal-editar-subtitle{margin:.4rem 0 0;font-family:Urbanist,sans-serif;font-size:.85rem;color:var(--brief-ink-soft)}.modal-close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#999;transition:color .2s ease;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px}.modal-close-btn:hover{color:var(--brief-navy);background:#0000000d}.alert{margin:0;padding:1rem;border-left:4px solid;border-radius:8px;font-family:Urbanist,sans-serif;font-size:.9rem}.alert.alert-warning{background:#fb923c2e;border-left-color:#f57c00;color:#92400e;margin:1rem 1.5rem 0}.alert.alert-danger{background:#ef44442e;border-left-color:#dc2626;color:#7f1d1d;margin:1rem 1.5rem 0}.alert strong{display:block;margin-bottom:.3rem;font-weight:700}.modal-editar-paso{padding:1.5rem;min-height:300px;display:flex;flex-direction:column}.paso-titulo{font-family:Archivo,sans-serif;font-size:1.1rem;font-weight:700;color:var(--brief-navy);margin-bottom:1.2rem;letter-spacing:-.01em}.modal-textarea-motivo{width:100%;padding:.75rem;border:1px solid rgb(13 48 75 / .18);border-radius:11px;font-family:Urbanist,sans-serif;font-size:.9rem;color:var(--brief-navy);resize:vertical;min-height:100px;transition:border-color .2s ease,box-shadow .2s ease;background:#fff}.modal-textarea-motivo:focus{outline:none;border-color:var(--brief-cyan-deep);box-shadow:0 0 0 3px #2ec7c22e;background:#fafbff}.modal-textarea-motivo.error{border-color:#dc2626;background:#ef444414}.campo-error{display:block;color:#dc2626;font-family:Urbanist,sans-serif;font-size:.8rem;font-weight:600;margin-top:.4rem}.campo-hint{display:block;color:var(--brief-ink-soft);font-family:Urbanist,sans-serif;font-size:.8rem;margin-top:.5rem;font-style:italic}.secciones-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}.seccion-checkbox{display:flex;align-items:center;gap:.75rem;padding:1rem;border:2px solid rgb(13 48 75 / .18);border-radius:11px;cursor:pointer;transition:all .2s ease;background:#fff;-webkit-user-select:none;user-select:none}.seccion-checkbox:hover{border-color:var(--brief-cyan);background:#2ec7c20d}.seccion-checkbox.selected{border-color:var(--brief-cyan);background:#2ec7c21f}.seccion-checkbox input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:var(--brief-cyan)}.checkbox-label{font-family:Urbanist,sans-serif;font-weight:600;color:var(--brief-navy);font-size:.9rem}.modal-editar-comparaciones{flex:1;overflow-y:auto;margin-bottom:1.5rem;padding-bottom:1rem}.seccion-cambios{margin-bottom:1.5rem}.seccion-cambios h4{margin:0 0 1rem;font-family:Archivo,sans-serif;font-weight:700;font-size:1rem;color:var(--brief-navy);padding-bottom:.8rem;border-bottom:2px solid rgb(46,199,194,.3)}.modal-acciones{display:flex;justify-content:space-between;gap:1rem;padding-top:1rem;border-top:1px solid rgb(0 0 0 / .08);flex-shrink:0}.modal-acciones .btn{flex:1;border:none;border-radius:11px;min-height:40px;padding:.56rem .92rem;font-family:Urbanist,sans-serif;font-size:.84rem;font-weight:700;cursor:pointer;transition:transform .16s ease,box-shadow .2s ease;display:inline-flex;align-items:center;justify-content:center}.modal-acciones .btn-primary{color:#fff;background:linear-gradient(135deg,var(--brief-cyan),var(--brief-cyan-deep));box-shadow:0 12px 22px #16aca74d}.modal-acciones .btn-primary:hover:not(:disabled){box-shadow:0 14px 28px #16aca766;transform:translateY(-1px)}.modal-acciones .btn-secondary{color:#fff;background:linear-gradient(135deg,#4f6d87,#35506a);box-shadow:0 12px 20px #35506a38}.modal-acciones .btn-secondary:hover:not(:disabled){box-shadow:0 14px 26px #35506a4d;transform:translateY(-1px)}.btn:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.modal-editar-overlay{padding:0}.modal-editar-content{max-width:100%;max-height:100vh;border-radius:0}.modal-editar-header{flex-direction:column;gap:1rem}.modal-editar-header h2{font-size:1.1rem}.secciones-grid{grid-template-columns:1fr}.modal-acciones{flex-direction:column-reverse}.modal-acciones .btn{width:100%}.modal-editar-paso{padding:1.2rem}}.filter-tag-remove:hover{color:#c62828}@media (max-width: 1200px){.filters-grid{grid-template-columns:1fr 1fr}}@media (max-width: 1024px){.brief-table thead th,.brief-table tbody td{padding:.75rem;font-size:.85rem}.briefs-header h1{font-size:1.8rem}}@media (max-width: 768px){.briefs-main{padding:1rem}.briefs-header{flex-direction:column;align-items:stretch;gap:.75rem}.briefs-header h1{font-size:1.5rem}.filters-grid{grid-template-columns:1fr;gap:.75rem}.filter-input,.filter-select{padding:.65rem;font-size:.9rem}.brief-table{font-size:.85rem}.brief-table thead th,.brief-table tbody td{padding:.5rem}.brief-table .cliente,.brief-table .producto{max-width:120px}.modal-content{width:95vw;max-width:95vw}.pagination-controls{flex-direction:column;gap:.5rem}.pagination-info{font-size:.85rem}.confirmacion-content{width:95vw}.confirmacion-actions{flex-direction:column}.btn{width:100%}}.modal-generar-brief{max-width:680px;width:90%}.modal-generar-brief .modal-body{padding:2rem}.modal-generar-brief .modal-footer{padding:1.5rem 2rem;gap:1rem;justify-content:center;flex-wrap:wrap}.btn-close{background:none;border:none;font-size:1.8rem;cursor:pointer;color:#999;transition:color .2s ease;padding:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:6px}.btn-close:hover{color:var(--brief-navy);background:#0000000d}.paso-1,.paso-2,.paso-3{display:grid;gap:1.2rem;animation:briefs-fadeUp .32s ease both}.paso-1 h3,.paso-2 h3,.paso-3 h3{margin:0 0 .8rem;font-family:Archivo,sans-serif;font-weight:700;font-size:1.16rem;color:var(--brief-navy);letter-spacing:-.01em}.search-group{position:relative}.search-group input{width:100%;padding:.88rem 1rem;border:2px solid rgb(13 48 75 / .18);border-radius:14px;font-family:Urbanist,sans-serif;font-size:.95rem;color:var(--brief-navy);transition:all .2s ease;background:#fff}.search-group input:focus{outline:none;border-color:var(--brief-cyan);box-shadow:0 0 0 4px #2ec7c226;background:#fafbff}.search-group input::placeholder{color:#999;font-weight:500}.cotizaciones-list{display:grid;gap:.8rem;max-height:360px;overflow-y:auto;padding-right:.5rem}.cotizaciones-list::-webkit-scrollbar{width:6px}.cotizaciones-list::-webkit-scrollbar-track{background:#0000000d;border-radius:3px}.cotizaciones-list::-webkit-scrollbar-thumb{background:#2ec7c24d;border-radius:3px}.cotizaciones-list::-webkit-scrollbar-thumb:hover{background:#2ec7c280}.cotizacion-item{padding:1rem;border:2px solid rgb(13 48 75 / .15);border-radius:12px;cursor:pointer;transition:all .2s ease;background:#fff;-webkit-user-select:none;user-select:none}.cotizacion-item:hover{border-color:var(--brief-cyan);background:#2ec7c20f;transform:translate(4px)}.cotizacion-item.active{border-color:var(--brief-cyan);background:linear-gradient(135deg,#2ec7c226,#16aca714);box-shadow:0 8px 20px #2ec7c233}.item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.item-header strong{font-family:Archivo,sans-serif;font-size:1rem;font-weight:700;color:var(--brief-navy)}.item-monto{font-family:Urbanist,sans-serif;font-weight:600;color:var(--brief-cyan);font-size:.95rem}.item-subtext{font-family:Urbanist,sans-serif;font-size:.85rem;color:var(--brief-ink-soft)}.items-list{display:grid;gap:.8rem;max-height:360px;overflow-y:auto;padding-right:.5rem}.item-card{padding:1.2rem;border:2px solid rgb(13 48 75 / .15);border-radius:12px;cursor:pointer;transition:all .2s ease;background:#fff;-webkit-user-select:none;user-select:none}.item-card:hover{border-color:var(--brief-cyan);background:#2ec7c20f;transform:translate(4px)}.item-card.active{border-color:var(--brief-cyan);background:linear-gradient(135deg,#2ec7c226,#16aca714);box-shadow:0 8px 20px #2ec7c233}.item-number{font-family:Archivo,sans-serif;font-size:.8rem;font-weight:700;color:var(--brief-cyan);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.4rem}.item-desc{font-family:Urbanist,sans-serif;font-size:.9rem;color:var(--brief-navy);font-weight:600;margin-bottom:.6rem;line-height:1.4}.item-price{font-family:Archivo,sans-serif;font-size:1.08rem;font-weight:700;color:var(--brief-cyan-deep)}.info-box{padding:1rem;background:linear-gradient(135deg,#2ec7c21f,#0d304b0f);border:1px solid rgba(46,199,194,.2);border-radius:12px;margin-bottom:1rem}.info-box p{margin:.4rem 0;font-family:Urbanist,sans-serif;font-size:.9rem;color:var(--brief-navy);line-height:1.5}.info-box p strong{color:var(--brief-navy);font-weight:700}.form-control{width:100%;padding:.75rem;border:1px solid rgb(13 48 75 / .18);border-radius:11px;font-family:Urbanist,sans-serif;font-size:.9rem;color:var(--brief-navy);transition:border-color .2s ease,box-shadow .2s ease;background:#fff}.form-control:focus{outline:none;border-color:var(--brief-cyan-deep);box-shadow:0 0 0 3px #2ec7c22e;background:#fafbff}.form-control:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.form-row.full{grid-template-columns:1fr}.form-col-2{display:flex;flex-direction:column;gap:.5rem}.form-col-2 label{font-family:Urbanist,sans-serif;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--brief-navy)}.input-group{display:flex;align-items:center;gap:0;border:1px solid rgb(13 48 75 / .18);border-radius:11px;overflow:hidden;transition:border-color .2s ease,box-shadow .2s ease;background:#fff}.input-group input{flex:1;border:none;padding:.75rem;font-family:Urbanist,sans-serif;font-size:.9rem;color:var(--brief-navy);outline:none}.input-group input:focus{background:#fafbff}.input-addon{padding:.75rem .9rem;background:#00000005;color:var(--brief-navy);font-family:Urbanist,sans-serif;font-weight:700;font-size:.9rem;border-left:1px solid rgb(0 0 0 / .08);-webkit-user-select:none;user-select:none}.input-group:focus-within{border-color:var(--brief-cyan-deep);box-shadow:0 0 0 3px #2ec7c22e}.text-center{text-align:center}.text-muted{color:var(--brief-ink-soft);font-family:Urbanist,sans-serif;font-size:.9rem}.py-3{padding-top:1rem;padding-bottom:1rem}@media (max-width: 768px){.modal-generar-brief{width:95%;max-width:95%}.modal-generar-brief .modal-body{padding:1.5rem}.modal-generar-brief .modal-footer{padding:1.2rem 1.5rem;flex-direction:column}.modal-generar-brief .modal-footer .btn{width:100%}.form-row{grid-template-columns:1fr}.cotizaciones-list,.items-list{max-height:280px}.item-card{padding:1rem}.cotizacion-item{padding:.9rem}}@media (max-width: 480px){.briefs-main{padding:.75rem;gap:1rem}.briefs-header h1{font-size:1.3rem}.brief-table{font-size:.75rem}.brief-table thead th,.brief-table tbody td{padding:.35rem}.badge{padding:.3rem .6rem;font-size:.7rem}.modal-body{padding:1rem}.modal-generar-brief{width:98%;max-width:98%}.modal-generar-brief .modal-body{padding:1.2rem}.paso-1 h3,.paso-2 h3,.paso-3 h3{font-size:1.05rem}.search-group input{font-size:.9rem;padding:.75rem}.form-col-2 label{font-size:.75rem}.item-desc{font-size:.85rem}.item-price{font-size:1rem}}.formato-c-container{max-width:1200px;margin:0 auto;padding:30px 20px;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:12px;box-shadow:0 4px 15px #0000001a}.formato-c-container h2{color:#2c3e50;font-size:2em;margin-bottom:30px;text-align:center;font-weight:600}.erro-box{background:#fee;border-left:4px solid #e74c3c;padding:15px;margin-bottom:20px;border-radius:6px;color:#c0392b}.erro-box h4{margin-top:0;font-weight:600}.erro-box ul{margin:10px 0 0 20px;padding:0}.erro-box li{margin:5px 0;font-size:.95em}.formato-c-form{background:#fff;padding:40px;border-radius:10px;box-shadow:0 2px 10px #0000000d}.form-section{border:2px solid #e0e6ed;border-radius:8px;padding:25px;margin-bottom:30px;background:#fafbfd}.form-section legend{font-size:1.3em;font-weight:600;color:#2c3e50;padding:0 10px;margin-bottom:20px}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:600;color:#34495e;margin-bottom:8px;font-size:.95em}.form-group input[type=text],.form-group input[type=date],.form-group select,.form-group textarea{width:100%;padding:12px 15px;border:2px solid #d0d8e0;border-radius:6px;font-size:.95em;font-family:inherit;transition:all .3s ease;background:#fff}.form-group input[type=text]:focus,.form-group input[type=date]:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3498db;outline:none;box-shadow:0 0 0 3px #3498db1a;background:#f8fbff}.form-group textarea{resize:vertical;min-height:100px}.form-group small{display:block;color:#7f8c8d;font-size:.85em;margin-top:5px;font-style:italic}.checkbox-group{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-top:10px}.checkbox-label{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#f5f7fa;border:2px solid #d0d8e0;border-radius:6px;cursor:pointer;transition:all .2s ease;font-weight:500;color:#34495e}.checkbox-label:hover{background:#ecf0f5;border-color:#3498db}.checkbox-label input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:#3498db}.checkbox-label input[type=checkbox]:checked{accent-color:#27ae60}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.form-actions{display:flex;gap:15px;justify-content:center;margin-top:40px;padding-top:20px;border-top:2px solid #e0e6ed}.btn-guardar,.btn-editar,.btn-cancelar{padding:12px 30px;font-size:1em;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.btn-guardar{background:linear-gradient(135deg,#27ae60,#229954);color:#fff;box-shadow:0 4px 12px #27ae604d}.btn-guardar:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #27ae6066}.btn-guardar:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-editar{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;padding:10px 25px;font-size:.9em}.btn-editar:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3498db4d}.btn-cancelar{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff}.btn-cancelar:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #e74c3c4d}.btn-cancelar:disabled{opacity:.6;cursor:not-allowed}.formato-c-view{background:#fff;padding:30px;border-radius:10px;box-shadow:0 2px 10px #0000000d}.formato-c-view h3{color:#2c3e50;margin-top:0;margin-bottom:20px;font-size:1.5em}.view-section{margin-bottom:25px;padding:15px;background:#f5f7fa;border-left:4px solid #3498db;border-radius:6px}.view-section h4{color:#2980b9;margin-top:0;margin-bottom:10px;font-size:1.1em}.view-section p{margin:8px 0;color:#34495e;line-height:1.6}.view-section strong{color:#2c3e50}.formato-c-loading{display:flex;justify-content:center;align-items:center;min-height:400px;font-size:1.2em;color:#7f8c8d;font-weight:600}@media (max-width: 768px){.formato-c-container{padding:20px 10px}.formato-c-form{padding:20px}.form-section{padding:15px}.checkbox-group{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.btn-guardar,.btn-cancelar{width:100%}}@media (max-width: 480px){.formato-c-container h2{font-size:1.5em}.form-section legend{font-size:1.1em}.checkbox-group{grid-template-columns:1fr}}.formato-a-container{padding:20px;background:linear-gradient(135deg,#f0f4f8,#e8f4f8);border-radius:8px;max-width:1000px;margin:0 auto}.formato-a-loading{text-align:center;padding:40px;font-size:16px;color:#666}.error-box{background-color:#fee;border-left:4px solid #e74c3c;color:#d32f2f;padding:15px;border-radius:4px;margin-bottom:20px;font-size:14px}.success-box{background-color:#efe;border-left:4px solid #27ae60;color:#27ae60;padding:15px;border-radius:4px;margin-bottom:20px;font-size:14px;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.formato-a-form{background:#fff;border-radius:8px;padding:30px;box-shadow:0 2px 8px #0000001a}.forma-section{border:2px solid #e0e7ff;border-radius:8px;padding:20px;margin-bottom:20px;background:#f9fafb}.forma-section legend{font-size:16px;font-weight:600;color:#2c3e50;padding:0 10px;text-align:left}.forma-section:nth-child(1){border-color:#bbdefb;background:linear-gradient(135deg,#f5f9ff,#f0f7ff)}.forma-section:nth-child(1) legend{color:#1565c0}.forma-section:nth-child(2){border-color:#c8e6c9;background:linear-gradient(135deg,#f5fff5,#f0fff0)}.forma-section:nth-child(2) legend{color:#2e7d32}.forma-section:nth-child(3){border-color:#fff9c4;background:linear-gradient(135deg,#fffef5,#fffef0)}.forma-section:nth-child(3) legend{color:#f57f17}.forma-section:nth-child(4){border-color:#ffccbc;background:linear-gradient(135deg,#fff5f0,#ffefeb)}.forma-section:nth-child(4) legend{color:#d84315}.forma-section:nth-child(5){border-color:#d1c4e9;background:linear-gradient(135deg,#f5f3ff,#f0eeff)}.forma-section:nth-child(5) legend{color:#512da8}.forma-section:nth-child(6){border-color:#f8bbd0;background:linear-gradient(135deg,#fff5f7,#fff0f5)}.forma-section:nth-child(6) legend{color:#c2185b}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:15px}.form-col{display:flex;flex-direction:column}.form-col.full-width{grid-column:1 / -1}.form-col label{font-weight:600;font-size:13px;color:#2c3e50;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.form-col input,.form-col select,.form-col textarea{padding:10px 12px;border:1px solid #d0d7de;border-radius:4px;font-size:14px;font-family:inherit;transition:all .3s ease;background:#fff}.form-col input:focus,.form-col select:focus,.form-col textarea:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;background:#f8fbff}.form-col input:disabled,.form-col select:disabled,.form-col textarea:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.form-col input.readonly{background-color:#efefef;color:#666;font-style:italic}.imagenes-section{display:flex;flex-direction:column;gap:15px}.imagenes-list{display:flex;flex-direction:column;gap:10px}.imagen-item{display:flex;justify-content:space-between;align-items:flex-start;padding:12px;background:#f0f7ff;border-left:3px solid #3498db;border-radius:4px;gap:10px}.imagen-info{flex:1}.imagen-url{font-size:12px;color:#3498db;word-break:break-all;margin:0 0 6px;font-weight:500}.imagen-desc{font-size:13px;color:#555;margin:0;font-style:italic}.btn-eliminar{background:#e74c3c;color:#fff;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;transition:all .2s;flex-shrink:0}.btn-eliminar:hover{background:#c0392b;transform:scale(1.1)}.nueva-imagen{padding:15px;border:2px dashed #3498db;border-radius:6px;background:#f8fbff;display:flex;flex-direction:column;gap:10px}.nueva-imagen input,.nueva-imagen textarea{padding:10px;border:1px solid #3498db;border-radius:4px;font-size:13px;font-family:inherit}.nueva-imagen input:focus,.nueva-imagen textarea:focus{outline:none;border-color:#2980b9;background:#fff;box-shadow:0 0 0 2px #3498db33}.botones-accion{display:flex;gap:10px;margin-top:30px;padding-top:20px;border-top:1px solid #e0e0e0}.btn{padding:10px 20px;border:none;border-radius:4px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s;text-transform:uppercase;letter-spacing:.5px}.btn-primary:hover:not(:disabled){background:#2980b9;transform:translateY(-2px);box-shadow:0 4px 12px #3498db4d}.btn-success:hover:not(:disabled){background:#229954;transform:translateY(-2px);box-shadow:0 4px 12px #27ae604d}.btn-secondary:hover:not(:disabled){background:#7f8c8d;transform:translateY(-2px);box-shadow:0 4px 12px #95a5a64d}.btn-outline{background:transparent;color:#7f8c8d;border:2px solid #7f8c8d}.btn-outline:hover:not(:disabled){background:#7f8c8d;color:#fff}@media (max-width: 768px){.form-row{grid-template-columns:1fr}.formato-a-form{padding:15px}.forma-section{padding:15px;margin-bottom:15px}.botones-accion{flex-direction:column}.btn{width:100%}}.formato-b-container{max-width:900px;margin:0 auto;padding:20px;background:#f8f9fa;border-radius:8px}.formato-buttons{display:flex;gap:10px;margin-bottom:20px;justify-content:flex-end}.btn{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease}.btn-primary{background:#3498db;color:#fff}.btn-primary:hover:not(:disabled){background:#2980b9;transform:translateY(-2px)}.btn-success{background:#27ae60;color:#fff}.btn-success:hover:not(:disabled){background:#229954;transform:translateY(-2px)}.btn-secondary{background:#95a5a6;color:#fff}.btn-secondary:hover:not(:disabled){background:#7f8c8d}.btn-danger{background:#e74c3c;color:#fff}.btn-danger:hover:not(:disabled){background:#c0392b}.btn-small{padding:6px 12px;font-size:12px}.alert{padding:15px;border-radius:6px;margin-bottom:15px;font-weight:500}.alert-error{background:#fadbd8;color:#922b21;border-left:4px solid #e74c3c}.alert-success{background:#d5f4e6;color:#145a32;border-left:4px solid #27ae60}.form-section{background:#fff;border-left:5px solid #3498db;border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.form-section h3{margin:0 0 15px;color:#2c3e50;font-size:18px;display:flex;align-items:center;gap:10px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:15px}@media (max-width: 768px){.form-grid{grid-template-columns:1fr}}.form-group{display:flex;flex-direction:column}.form-group.full-width{grid-column:1 / -1}.form-group label{font-weight:600;color:#2c3e50;margin-bottom:8px;font-size:14px}.form-group input,.form-group select,.form-group textarea{padding:12px;border:1px solid #bdc3c7;border-radius:6px;font-family:inherit;font-size:14px;background:#fff;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px #3498db1a}.form-group input:disabled{background:#ecf0f1;cursor:not-allowed;color:#95a5a6}.form-group p{margin:0;padding:12px;background:#ecf0f1;border-radius:6px;color:#2c3e50;line-height:1.5}.form-group textarea{resize:vertical;min-height:80px}.fotos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:15px;margin-top:15px}.foto-card{border:2px solid #ecf0f1;border-radius:8px;overflow:hidden;text-align:center;transition:transform .3s ease,box-shadow .3s ease}.foto-card:hover{transform:translateY(-3px);box-shadow:0 4px 12px #00000026}.foto-card img{width:100%;height:120px;object-fit:cover;display:block}.foto-card p{margin:10px;font-size:12px;color:#2c3e50;word-break:break-word}.fotos-editor{margin-top:15px}.subidor-fotos{margin-bottom:15px}.fotos-lista{display:flex;flex-direction:column;gap:10px;margin-top:15px}.foto-item{display:flex;gap:10px;align-items:center;background:#ecf0f1;padding:10px;border-radius:6px}.foto-item input{flex:1}.text-muted{color:#95a5a6;font-style:italic}@media (max-width: 600px){.formato-b-container{padding:10px}.form-section{padding:15px}.form-section h3{font-size:16px}.fotos-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}:root{--brief-cyan: #2ec7c2;--brief-cyan-deep: #16aca7;--brief-navy: #0d304b;--brief-ink-soft: #546d7e;--brief-bg-card: rgb(255 255 255 / .88)}.detalles-brief-page{display:flex;flex-direction:column;min-height:100vh;background:radial-gradient(940px 560px at 6% 8%,rgb(46 199 194 / .13),transparent 62%),radial-gradient(900px 520px at 95% 92%,rgb(13 48 75 / .11),transparent 62%),linear-gradient(180deg,#f6fbff,#edf4fb 58%,#e8f0f8)}.detalles-main{flex:1;width:min(1380px,calc(100% - 2rem));margin:0 auto;padding:2rem 0 2.4rem;display:grid;gap:1.5rem}.detalles-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;animation:detalles-fadeUp .42s ease both}.header-left{flex:1}.header-title-row{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap}.header-left h1{margin:0;font-family:Archivo,sans-serif;font-weight:800;font-size:clamp(1.8rem,3vw,2.5rem);line-height:1.1;letter-spacing:-.02em;color:var(--brief-navy);word-break:break-word}.estado-badge{display:inline-flex;align-items:center;padding:.4rem .8rem;border-radius:8px;font-family:Urbanist,sans-serif;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.estado-badge.estado-generado{background-color:#2ec7c233;color:var(--brief-cyan-deep);border:1px solid var(--brief-cyan)}.estado-badge.estado-bloqueado{background-color:#ef444433;color:#dc2626;border:1px solid #dc2626;animation:pulse-warning 2s infinite}@keyframes pulse-warning{0%,to{opacity:1}50%{opacity:.7}}.ediciones-badge{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--brief-cyan),var(--brief-cyan-deep));color:#fff;font-family:Archivo,sans-serif;font-size:.9rem;font-weight:700;box-shadow:0 4px 12px #16aca74d;transition:all .3s ease}.ediciones-progress{display:flex;align-items:center;gap:.6rem;margin-top:.8rem;padding:.8rem;background:#fff9;border-radius:8px;border:1px solid rgb(46 199 194 / .3)}.ediciones-progress-bar{flex:1;height:6px;background-color:#0000001a;border-radius:3px;overflow:hidden}.ediciones-progress-fill{height:100%;background:linear-gradient(90deg,var(--brief-cyan),var(--brief-cyan-deep));transition:width .4s cubic-bezier(.34,1.56,.64,1);border-radius:3px;box-shadow:0 0 8px #2ec7c280}.ediciones-progress-label{font-family:Urbanist,sans-serif;font-size:.75rem;font-weight:600;color:var(--brief-cyan-deep);white-space:nowrap}.estado-badge.estado-bloqueado{background-color:#ef444433;color:#dc2626;border:1px solid #dc2626;animation:pulse-locked 2.5s ease-in-out infinite}@keyframes pulse-locked{0%{box-shadow:0 0 #dc2626b3}50%{box-shadow:0 0 0 4px #dc26264d}to{box-shadow:0 0 #dc262600}}.header-left .subtitle{margin:.5rem 0 0;font-family:Urbanist,sans-serif;font-size:1.05rem;color:var(--brief-ink-soft)}.alert{margin-top:.8rem;padding:.8rem 1rem;border-radius:8px;font-size:.875rem;font-family:Urbanist,sans-serif;font-weight:500}.alert-warning{background-color:#fde04733;border-left:3px solid #fbbf24;color:#92400e}.header-actions{display:flex;gap:.8rem;flex-wrap:wrap;justify-content:flex-end}.btn{border:none;border-radius:11px;min-height:40px;padding:.56rem 1rem;font-family:Urbanist,sans-serif;font-size:.84rem;font-weight:700;cursor:pointer;transition:transform .16s ease,box-shadow .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn:hover{transform:translateY(-1px)}.btn-primary{color:#fff;background:linear-gradient(135deg,var(--brief-cyan),var(--brief-cyan-deep));box-shadow:0 12px 22px #16aca74d}.btn-outline{color:var(--brief-navy);background:#fff;border:1px solid rgb(13 48 75 / .2);box-shadow:0 2px 8px #00000014}.btn-outline:hover{background:#fafbff;border-color:var(--brief-cyan)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn-primary:disabled{background:linear-gradient(135deg,#a0a0a0,#7a7a7a);box-shadow:0 4px 12px #0003}.detalles-container{display:grid;grid-template-columns:1fr 320px;gap:1.5rem}.detalles-content{border-radius:22px;border:1px solid rgb(255 255 255 / .95);background:var(--brief-bg-card);box-shadow:0 22px 38px #112e4817;overflow:hidden;animation:detalles-fadeUp .48s ease both}.tabs-navigation{display:flex;gap:0;border-bottom:2px solid rgb(0 0 0 / .08);background:#f5fbfd80;flex-wrap:wrap}.tab-btn{flex:1;min-width:150px;padding:1rem 1.2rem;background:none;border:none;border-bottom:3px solid transparent;color:var(--brief-ink-soft);font-family:Urbanist,sans-serif;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease;text-align:center;letter-spacing:.3px}.tab-btn:hover{color:var(--brief-navy);background-color:#f0f9ff80}.tab-btn.active{color:var(--brief-navy);border-bottom-color:var(--brief-cyan);background-color:#2ec7c20d}.tab-content{padding:2rem}.info-section{margin-bottom:2.5rem}.info-section:last-child{margin-bottom:0}.info-section h2{margin:0 0 1.2rem;font-family:Archivo,sans-serif;font-weight:700;font-size:1.1rem;color:var(--brief-navy);padding-bottom:.8rem;border-bottom:2px solid var(--brief-cyan);letter-spacing:-.01em}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.info-item{display:flex;flex-direction:column;gap:.4rem}.info-item.full-width{grid-column:1 / -1}.info-item label{font-family:Urbanist,sans-serif;font-weight:700;font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:var(--brief-navy)}.info-item p{font-family:Urbanist,sans-serif;color:var(--brief-ink-soft);font-size:.95rem;margin:0;word-break:break-word}.info-item .description{background:#f5fbfdcc;border-left:3px solid var(--brief-cyan);padding:1rem;border-radius:8px;line-height:1.6;white-space:pre-wrap}.json-display{background-color:#f5f5f5;border:1px solid #ddd;border-radius:8px;overflow-x:auto}.json-display pre{margin:0;padding:1rem;font-family:Courier New,monospace;font-size:.85rem;color:#333;line-height:1.5}.historial-list{display:flex;flex-direction:column;gap:1.2rem}.historial-item{padding:1.2rem;border:1px solid rgb(0 0 0 / .08);border-radius:12px;background:#f5fbfd80;transition:all .2s ease}.historial-item:hover{box-shadow:0 4px 12px #2ec7c21f}.historial-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.8rem;border-bottom:1px solid rgb(0 0 0 / .08)}.edicion-numero{font-family:Archivo,sans-serif;font-weight:700;color:var(--brief-cyan);font-size:1.05rem}.edicion-fecha{font-family:Urbanist,sans-serif;color:#999;font-size:.85rem}.historial-motivo{margin:0 0 .5rem;font-family:Urbanist,sans-serif;color:var(--brief-navy);font-weight:500}.historial-usuario{margin:0 0 .8rem;font-family:Urbanist,sans-serif;color:var(--brief-ink-soft);font-size:.9rem}.historial-campos{background-color:#fff;border-left:3px solid var(--brief-cyan);padding:.8rem 1rem;border-radius:6px}.historial-campos strong{display:block;margin-bottom:.5rem;font-family:Urbanist,sans-serif;color:var(--brief-navy)}.historial-campos ul{margin:0;padding-left:1.5rem}.historial-campos li{font-family:Urbanist,sans-serif;color:var(--brief-ink-soft);font-size:.9rem;line-height:1.5}.detalles-sidebar{height:fit-content;position:sticky;top:20px}.brief-sidebar{border-radius:22px;border:1px solid rgb(255 255 255 / .95);background:linear-gradient(145deg,#0d304bf5,#134162eb);color:#fff;padding:1.5rem;box-shadow:0 22px 38px #112e4826;display:grid;gap:1.2rem;animation:detalles-fadeUp .52s ease 70ms both}.sidebar-section{display:grid;gap:.8rem}.sidebar-title{font-family:Urbanist,sans-serif;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#f0f9ffd1;margin:0 0 .4rem}.badge-lg{display:block;padding:.8rem;text-align:center;border-radius:11px;border:1px solid rgb(255 255 255 / .2);background:#ffffff14;font-family:Urbanist,sans-serif;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#fff}.ediciones-counter{text-align:center;padding:1rem;border-radius:14px;border:1px solid rgb(255 255 255 / .16);background:#ffffff14}.counter-display{display:flex;align-items:baseline;justify-content:center;gap:.2rem;margin-bottom:.4rem}.counter-display .numero{font-family:Archivo,sans-serif;font-size:2.5rem;font-weight:800;color:#fff}.counter-display .slash{font-size:1.4rem;color:#fff6}.counter-display .total{font-size:1.2rem;color:#fff9}.counter-label{font-family:Urbanist,sans-serif;font-size:.8rem;color:#f0f9ffd1}.info-list{display:flex;flex-direction:column;gap:.8rem}.info-list .info-item{display:grid;gap:.2rem}.info-list .label{font-family:Urbanist,sans-serif;font-weight:700;font-size:.7rem;text-transform:uppercase;color:#f0f9ffd1;letter-spacing:.05em}.info-list .valor{font-family:Urbanist,sans-serif;font-size:.9rem;color:#fff;word-break:break-word}.sidebar-actions{display:flex;flex-direction:column;gap:.8rem;padding-top:.8rem;border-top:1px solid rgb(255 255 255 / .16)}.sidebar-actions .btn{width:100%;background:linear-gradient(135deg,var(--brief-cyan),var(--brief-cyan-deep));color:#fff;box-shadow:0 8px 16px #16aca74d;padding:.7rem 1rem;font-size:.8rem;min-height:38px}.sidebar-actions .btn:hover{box-shadow:0 10px 20px #16aca766}.sidebar-descargar{background:linear-gradient(135deg,#4f6d87,#35506a);box-shadow:0 8px 16px #35506a3d}.sidebar-descargar:hover{box-shadow:0 10px 20px #35506a4d}.sidebar-note{margin-top:1rem;padding:.8rem;background:#ffffff14;border:1px solid rgb(255 255 255 / .16);border-radius:10px;font-size:.75rem}.sidebar-note p{margin:0;color:#f0f9ffd1;line-height:1.5}.loading-state,.error-state{min-height:400px;padding:3rem 2rem;text-align:center;background:#fff;border-radius:22px;border:1px solid rgb(255 255 255 / .95);box-shadow:0 22px 38px #112e4817;display:flex;flex-direction:column;align-items:center;justify-content:center}.historial-expandible-container{display:flex;flex-direction:column;gap:.5rem;width:100%;animation:detalles-fadeUp .42s ease both}.historial-vacio{padding:3rem 2rem;text-align:center;background:linear-gradient(135deg,#f5fbfdcc,#f0f7fb99);border:2px dashed rgb(46 199 194 / .3);border-radius:16px;color:var(--brief-ink-soft);font-family:Urbanist,sans-serif;font-size:1rem}.historial-expandible-tabla{width:100%;border-collapse:collapse;background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 4px 12px #2ec7c21f;border:1px solid rgb(46 199 194 / .15)}.historial-expandible-tabla thead{background:linear-gradient(90deg,var(--brief-cyan),var(--brief-cyan-deep));color:#fff;text-transform:uppercase;font-size:.8rem;font-weight:700;letter-spacing:.04em}.historial-expandible-tabla thead th{padding:1rem 1.2rem;text-align:left;font-family:Archivo,sans-serif;border-right:1px solid rgb(255 255 255 / .2)}.historial-expandible-tabla thead th:last-child{border-right:none}.col-expand{width:50px;text-align:center}.col-edicion{width:140px}.col-motivo{flex:1;min-width:200px}.col-campos{width:140px}.col-fecha{width:150px}.col-usuario{width:130px}.historial-fila{border-bottom:1px solid rgb(46 199 194 / .1);transition:all .2s ease}.historial-fila:hover{background:#2ec7c20d;box-shadow:inset 0 0 8px #2ec7c214}.historial-expandible-tabla tbody td{padding:1.1rem 1.2rem;font-family:Urbanist,sans-serif;color:var(--brief-ink-soft);font-size:.95rem;vertical-align:middle}.historial-generacion{background:linear-gradient(90deg,#2ec7c214,#16aca70d);font-weight:600}.historial-generacion strong{color:var(--brief-cyan);font-family:Archivo,sans-serif}.expand-btn{background:none;border:none;color:var(--brief-cyan);font-size:1.2rem;cursor:pointer;padding:.4rem .6rem;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease;font-weight:700}.expand-btn:hover{background:#2ec7c226;transform:scale(1.15)}.expand-btn:active{transform:scale(.95)}.campo-badge{display:inline-block;padding:.35rem .75rem;background:linear-gradient(135deg,var(--brief-cyan),var(--brief-cyan-deep));color:#fff;border-radius:20px;font-size:.8rem;font-weight:700;font-family:Archivo,sans-serif;box-shadow:0 4px 8px #16aca740;letter-spacing:.02em}.motivo-texto{color:var(--brief-navy);font-weight:500}.historial-detalle{display:none;border:none}.historial-detalle-expanded{display:table-row;background:#f5fbfd80;animation:slideDown .3s ease}.historial-detalle td{padding:0!important;border:none}.detalle-contenido{padding:1.5rem 1.2rem 1.5rem 60px;display:flex;flex-direction:column;gap:1.2rem}.detalle-info{margin:0;color:var(--brief-ink-soft);font-size:.95rem;line-height:1.5;font-style:italic}.sin-cambios{padding:1rem;color:var(--brief-ink-soft);text-align:center;font-style:italic;background:#f0f9ff80;border-radius:8px;margin:0}.comparaciones-bloque{display:flex;flex-direction:column;gap:1rem;background:#fff;padding:1.2rem;border-radius:11px;border:1px solid rgb(46 199 194 / .15);box-shadow:inset 0 2px 4px #00000005}.detalle-acciones{display:flex;justify-content:flex-start;gap:.8rem;padding-top:.5rem}.btn.btn-sm{padding:.5rem 1rem;font-size:.8rem;min-height:36px;border-radius:8px;font-family:Urbanist,sans-serif;font-weight:600}.btn.btn-sm.btn-outline{color:var(--brief-cyan);background:#fff;border:1.5px solid var(--brief-cyan);transition:all .2s ease}.btn.btn-sm.btn-outline:hover{background:#2ec7c21a;box-shadow:0 4px 8px #2ec7c233}@keyframes slideDown{0%{opacity:0;max-height:0;transform:translateY(-10px)}to{opacity:1;max-height:600px;transform:translateY(0)}}@keyframes slideUp{0%{opacity:1;max-height:600px;transform:translateY(0)}to{opacity:0;max-height:0;transform:translateY(-10px)}}@media (max-width: 1100px){.historial-expandible-tabla{font-size:.9rem}.col-motivo{min-width:160px}.col-fecha{width:120px}.col-usuario{width:110px}.historial-expandible-tabla thead th,.historial-expandible-tabla tbody td{padding:.8rem}}@media (max-width: 768px){.historial-expandible-tabla{font-size:.85rem;display:block;border:none;box-shadow:none}.historial-expandible-tabla thead{display:none}.historial-expandible-tabla tbody{display:flex;flex-direction:column;gap:1rem}.historial-fila{display:grid;grid-template-columns:auto 1fr;gap:1rem;background:#fff;border:1px solid rgb(46 199 194 / .15);border-radius:12px;padding:1rem;margin-bottom:.5rem;box-shadow:0 4px 12px #2ec7c21a}.historial-fila:hover{background:#2ec7c20d}.historial-generacion{background:linear-gradient(135deg,#2ec7c21f,#16aca714)}.historial-expandible-tabla td{display:block;padding:.5rem 0!important}.col-expand{grid-column:1 / 2;grid-row:1 / 3;width:auto}.col-edicion{grid-column:2;width:auto;font-weight:700}.col-edicion strong{font-size:1rem}.col-motivo:before{content:"MOTIVO: ";font-weight:700;color:var(--brief-navy)}.col-campos:before{content:"CAMBIOS: ";font-weight:700;color:var(--brief-navy)}.col-fecha:before{content:"FECHA: ";font-weight:700;color:var(--brief-navy)}.col-usuario:before{content:"USUARIO: ";font-weight:700;color:var(--brief-navy)}.detalle-contenido{padding:1.2rem .8rem}.comparaciones-bloque{padding:1rem;gap:.8rem}}.loading-state p,.error-state p{font-family:Urbanist,sans-serif;color:var(--brief-ink-soft);font-size:1rem;margin:0 0 1rem}.error-state,.error-state p{color:#d32f2f}@keyframes detalles-fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1024px){.detalles-container{grid-template-columns:1fr}.detalles-sidebar{position:static}.tabs-navigation{flex-direction:column}.tab-btn{min-width:auto;text-align:left}}@media (max-width: 768px){.detalles-main{gap:1.2rem;padding:1.2rem 0 1.8rem}.header-left h1{font-size:1.5rem}.header-actions{width:100%;flex-direction:column}.header-actions .btn{width:100%}.tab-content{padding:1.2rem}.info-grid{grid-template-columns:1fr;gap:1rem}.brief-sidebar{padding:1.2rem}}.comparacion-campo{padding:1rem;background:linear-gradient(135deg,#f5fbfdcc,#f0f7fb99);border:1px solid rgb(46 199 194 / .2);border-radius:10px;display:flex;flex-direction:column;gap:.8rem;animation:slideDown .3s ease}.comparacion-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding-bottom:.8rem;border-bottom:1px solid rgb(46 199 194 / .15)}.comparacion-nombre{font-family:Archivo,sans-serif;font-weight:700;color:var(--brief-navy);font-size:.95rem;text-transform:uppercase;letter-spacing:.03em}.comparacion-badge{display:inline-block;padding:.3rem .6rem;background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff;border-radius:12px;font-size:.75rem;font-weight:700;font-family:Archivo,sans-serif;letter-spacing:.02em}.comparacion-contenido{display:grid;grid-template-columns:1fr auto 1fr;gap:1rem;align-items:center}.comparacion-columna{display:flex;flex-direction:column;gap:.5rem}.comparacion-label{font-family:Urbanist,sans-serif;font-weight:700;font-size:.8rem;text-transform:uppercase;color:var(--brief-navy);letter-spacing:.04em;opacity:.8}.comparacion-valor{padding:.8rem;background:#fff;border:1px solid rgb(46 199 194 / .15);border-radius:8px;font-family:Urbanist,sans-serif;font-size:.95rem;color:var(--brief-navy);line-height:1.5;word-break:break-word;min-height:40px;display:flex;align-items:center;white-space:pre-wrap}.comparacion-valor.deletado{background:#d32f2f0f;border-color:#d32f2f33;opacity:.7;text-decoration:line-through;color:#d32f2f}.comparacion-valor.insertado{background:#4caf500f;border-color:#4caf5033;color:#4caf50;font-weight:500}.comparacion-flecha{font-size:1.5rem;color:var(--brief-cyan);font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 .5rem;animation:arrowPulse .6s ease infinite}@keyframes arrowPulse{0%,to{transform:translate(0)}50%{transform:translate(4px)}}@media (max-width: 768px){.comparacion-campo{padding:.8rem;gap:.6rem}.comparacion-header{flex-direction:column;align-items:flex-start;gap:.5rem}.comparacion-contenido{grid-template-columns:1fr;gap:.8rem}.comparacion-flecha{transform:rotate(90deg);font-size:1.2rem;padding:.3rem 0}.comparacion-valor{padding:.6rem;font-size:.9rem;min-height:auto}}.App{min-height:100vh}:root{--primary-color: #2563eb;--primary-dark: #1d4ed8;--secondary-color: #64748b;--success-color: #10b981;--danger-color: #ef4444;--warning-color: #f59e0b;--bg-color: #f8fafc;--text-color: #1e293b;--border-color: #e2e8f0;--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-color);color:var(--text-color);line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.btn{padding:.5rem 1rem;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-dark)}.btn-secondary{background-color:var(--secondary-color);color:#fff}.btn-success{background-color:var(--success-color);color:#fff}.btn-danger{background-color:var(--danger-color);color:#fff}.input{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:.375rem;font-size:.875rem;width:100%;transition:border-color .2s}.input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.select{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:.375rem;font-size:.875rem;width:100%;background-color:#fff;cursor:pointer}.card{background:#fff;border-radius:.5rem;padding:1.5rem;box-shadow:var(--shadow)}.alert{padding:.75rem 1rem;border-radius:.375rem;margin-bottom:1rem}.alert-success{background-color:#d1fae5;color:#065f46;border:1px solid #6ee7b7}.alert-error{background-color:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.alert-warning{background-color:#fef3c7;color:#92400e;border:1px solid #fcd34d}.table{width:100%;border-collapse:collapse;margin-top:1rem}.table th,.table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--border-color)}.table th{background-color:#f8fafc;font-weight:600;font-size:.875rem;color:var(--secondary-color);text-transform:uppercase}.table tbody tr:hover{background-color:#f8fafc}.spinner{border:3px solid #f3f3f3;border-top:3px solid var(--primary-color);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:2rem auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
