@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap";:root{color-scheme:light;--bg: #f5efe4;--bg-accent: #f6f7fb;--ink: #1e293b;--muted: #64748b;--line: rgba(15, 23, 42, .12);--panel: rgba(255, 255, 255, .82);--panel-strong: #ffffff;--brand: #b45309;--brand-dark: #7c2d12;--success: #166534;--error: #b91c1c;--shadow: 0 24px 80px rgba(15, 23, 42, .12)}*,*:before,*:after{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;font-family:Manrope,system-ui,sans-serif;color:var(--ink);background:radial-gradient(circle at top left,rgba(180,83,9,.18),transparent 28%),radial-gradient(circle at right center,rgba(37,99,235,.14),transparent 25%),linear-gradient(180deg,#f8f4ec,#eef2ff)}button,input{font:inherit}button{cursor:pointer}code{font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:.92em}.portal-shell{display:grid;grid-template-columns:320px 1fr;min-height:100vh}.portal-shell--centered{display:grid;place-items:center;min-height:100vh;padding:24px}.portal-auth{min-height:100vh;display:grid;grid-template-columns:minmax(320px,1.15fr) minmax(320px,460px);gap:28px;align-items:center;padding:40px}.portal-auth__brand{padding:48px}.portal-auth__brand h1{margin:10px 0 14px;font-size:clamp(2.4rem,5vw,4.7rem);line-height:.95;letter-spacing:-.05em;max-width:8ch}.portal-auth__brand p{max-width:56ch;color:var(--muted);font-size:1rem}.portal-auth__badge,.eyebrow{display:inline-flex;align-items:center;gap:8px;text-transform:uppercase;letter-spacing:.16em;font-size:.75rem;font-weight:800;color:var(--brand-dark)}.portal-auth__badge{padding:8px 12px;border-radius:999px;background:#ffffffbf;border:1px solid rgba(124,45,18,.14)}.login-card,.pulse-card,.workspace-card,.stat-card{background:var(--panel);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--line);box-shadow:var(--shadow)}.login-card{border-radius:28px;padding:28px}.login-card__header h2{margin:10px 0 0;font-size:1.8rem;letter-spacing:-.04em}.field{display:grid;gap:8px;margin-top:18px}.field span{font-size:.88rem;font-weight:700;color:var(--muted)}.field input{height:50px;border-radius:16px;border:1px solid rgba(15,23,42,.12);background:#ffffffdb;padding:0 16px;transition:border-color .12s ease,transform .12s ease,box-shadow .12s ease}.field input:focus{outline:none;border-color:#b4530973;box-shadow:0 0 0 4px #b453091f}.primary-button,.ghost-button{border-radius:16px;border:1px solid transparent;min-height:48px;padding:0 18px;font-weight:800}.primary-button{width:100%;margin-top:18px;background:linear-gradient(135deg,#c2410c,#1d4ed8);color:#fff}.ghost-button{background:#fff9;border-color:#fff3;color:#f8fafc}.login-card__hint,.inline-alert{margin-top:16px;border-radius:14px;padding:12px 14px;font-size:.92rem}.login-card__hint{background:#0f172a0a;color:var(--muted)}.inline-alert--error{background:#b91c1c14;color:var(--error);border:1px solid rgba(185,28,28,.12)}.portal-sidebar{display:flex;flex-direction:column;gap:20px;padding:28px 22px;background:linear-gradient(180deg,#1e293bf5,#0f172af5),linear-gradient(180deg,rgba(37,99,235,.3),transparent);color:#f8fafc}.portal-sidebar__kicker{font-size:.74rem;text-transform:uppercase;letter-spacing:.18em;color:#f8fafc99}.portal-sidebar__title{font-size:1.9rem;font-weight:800;letter-spacing:-.05em}.portal-sidebar__user{margin-top:12px;font-size:1rem;font-weight:700}.portal-sidebar__meta,.portal-sidebar__label{color:#f8fafca6;font-size:.88rem}.portal-sidebar__section{display:grid;gap:12px;min-height:0;flex:1}.portal-app-list{display:grid;gap:10px;align-content:start;overflow:auto}.portal-app-item{text-align:left;display:grid;gap:6px;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;color:inherit;padding:14px}.portal-app-item strong{font-size:.96rem}.portal-app-item span,.portal-app-empty{font-size:.84rem;color:#f8fafcb3}.portal-app-item.is-active{background:linear-gradient(135deg,#fbbf2438,#3b82f62e);border-color:#fbbf2457}.portal-main{padding:28px;display:grid;gap:22px}.portal-hero,.workspace-card,.stat-card,.pulse-card{border-radius:26px}.portal-hero{display:flex;justify-content:space-between;gap:20px;align-items:flex-start;padding:28px;background:#ffffffa8;border:1px solid rgba(255,255,255,.75);box-shadow:var(--shadow)}.portal-hero h1{margin:10px 0 12px;font-size:clamp(2rem,3vw,3.5rem);line-height:.95;letter-spacing:-.06em}.portal-hero p{max-width:76ch;color:var(--muted)}.hero-badges,.permission-row{display:flex;flex-wrap:wrap;gap:10px}.status-pill,.soft-tag{display:inline-flex;align-items:center;min-height:34px;padding:0 14px;border-radius:999px;background:#0f172a0f;color:var(--ink);font-size:.83rem;font-weight:700}.soft-tag--ok{background:#1665341f;color:var(--success)}.stats-grid,.workspace-grid{display:grid;gap:18px}.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.workspace-grid{grid-template-columns:minmax(0,1.5fr) minmax(320px,1fr)}.stat-card{padding:20px}.stat-card span{display:block;color:var(--muted);font-size:.84rem}.stat-card strong{display:block;margin-top:10px;font-size:1.1rem;letter-spacing:-.04em}.workspace-card{padding:24px}.workspace-card__header{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.workspace-card__header h2{margin:8px 0 0;font-size:1.55rem;letter-spacing:-.05em}.workspace-card__body{color:var(--muted);margin:16px 0 20px}.profile-grid{display:grid;gap:14px;margin:18px 0 0}.profile-item dt{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-weight:800}.profile-item dd{margin:6px 0 0;font-size:.96rem;font-weight:700}.pulse-card{width:min(420px,100%);padding:32px;text-align:center}.pulse-card__label{color:var(--brand-dark);text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;font-weight:800}.pulse-card__title{margin-top:12px;font-size:1.8rem;font-weight:800;letter-spacing:-.05em}.spinner{width:38px;height:38px;margin:18px auto 0;border-radius:50%;border:3px solid rgba(37,99,235,.16);border-top-color:var(--brand);animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 1120px){.portal-shell,.portal-auth,.workspace-grid,.stats-grid{grid-template-columns:1fr}.portal-sidebar{padding-bottom:16px}.portal-hero{flex-direction:column}}@media (max-width: 720px){.portal-auth,.portal-main,.portal-sidebar{padding:18px}.portal-auth__brand{padding:8px 2px}.login-card,.workspace-card,.portal-hero,.stat-card{border-radius:20px}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a85;display:grid;place-items:center;padding:24px;z-index:50}.modal-card{width:min(100%,720px);max-height:calc(100vh - 48px);overflow:auto;border-radius:28px;background:var(--panel-strong);border:1px solid var(--line);box-shadow:var(--shadow);padding:24px}.modal-card--wide{width:min(100%,920px)}.modal-card__header,.facturas-toolbar,.modal-card__actions,.factura-preview__hero{display:flex;align-items:center;justify-content:space-between;gap:16px}.modal-card__actions{justify-content:flex-end}.primary-button--small{padding:10px 14px;min-height:auto}.facturas-table-wrap{margin-top:18px;overflow:auto;border:1px solid var(--line);border-radius:18px;background:#ffffffb8}.facturas-table{width:100%;border-collapse:collapse;min-width:480px}.facturas-table th.num,.facturas-table td.num{text-align:right;font-variant-numeric:tabular-nums}.facturas-table th.actions,.facturas-table td.actions{text-align:right;width:1%;white-space:nowrap}.facturas-table th,.facturas-table td{padding:14px 16px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle}.facturas-table th{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.facturas-table tbody tr:hover{background:#b4530912}.facturas-empty{margin-top:18px;padding:22px;border:1px dashed var(--line);border-radius:18px;color:var(--muted);background:#ffffff73}.facturas-footer{margin-top:16px;display:flex;justify-content:center}.factura-preview{display:grid;gap:18px}.factura-preview__hero{margin-top:8px;padding:18px 20px;border-radius:18px;background:linear-gradient(135deg,#b453091f,#2563eb14)}.factura-preview__label,.preview-block__title{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:6px}.factura-preview__grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.factura-preview__body{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.preview-block{min-height:120px;padding:16px;border-radius:18px;border:1px solid var(--line);background:#f8fafce6}@media (max-width: 980px){.factura-preview__grid,.factura-preview__body{grid-template-columns:1fr 1fr}}@media (max-width: 760px){.modal-backdrop{padding:12px}.factura-preview__hero,.modal-card__header,.facturas-toolbar{flex-direction:column;align-items:flex-start}.factura-preview__grid,.factura-preview__body{grid-template-columns:1fr}}.portal-shell--minimal{display:flex;flex-direction:column;min-height:100vh}.portal-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 28px;background:var(--panel-strong);border-bottom:1px solid var(--line)}.portal-topbar__brand{display:flex;align-items:center;gap:12px}.portal-topbar__badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:999px;background:var(--brand);color:#fff;font-size:.78rem;font-weight:700;letter-spacing:.04em}.portal-topbar__title{font-weight:600;color:var(--ink)}.portal-topbar__user{display:flex;align-items:center;gap:14px}.portal-topbar__name{color:var(--muted);font-size:.92rem}.ghost-button--small{padding:8px 14px;min-height:auto;font-size:.88rem}.portal-main--minimal{width:min(100%,880px);margin:0 auto;padding:28px 24px 48px;display:flex;flex-direction:column;gap:20px}.portal-tabs{display:flex;flex-wrap:wrap;gap:8px}.portal-tab{padding:8px 16px;border-radius:999px;border:1px solid var(--line);background:transparent;color:var(--muted);cursor:pointer;font-size:.9rem;transition:all .15s ease}.portal-tab:hover{color:var(--ink)}.portal-tab.is-active{background:var(--brand);border-color:var(--brand);color:#fff}.portal-empty-state{padding:40px 24px;text-align:center;color:var(--muted);border:1px dashed var(--line);border-radius:18px;background:#ffffff80}.facturas-panel{display:flex;flex-direction:column}.facturas-panel__head{display:flex;align-items:center;justify-content:space-between;gap:16px}.facturas-panel__head h1{margin:0;font-size:1.6rem;color:var(--ink)}.link-button{background:none;border:none;padding:6px 8px;color:var(--brand);font-weight:600;cursor:pointer;font-size:.9rem}.link-button:hover{color:var(--brand-dark);text-decoration:underline}@media (max-width: 640px){.portal-topbar{padding:14px 18px}.portal-topbar__name{display:none}}.portal-topbar__sep{color:var(--muted);opacity:.6}.portal-topbar__crumb{background:none;border:none;color:var(--brand);cursor:pointer;font-size:.92rem;padding:0}.portal-topbar__crumb:hover{text-decoration:underline}.portal-topbar__current{color:var(--ink);font-weight:600}.menu-view{display:flex;flex-direction:column;gap:22px}.menu-view__head h1{margin:4px 0 6px;font-size:1.7rem;color:var(--ink)}.menu-view__head p{margin:0;color:var(--muted)}.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.menu-card{display:flex;flex-direction:column;gap:8px;padding:22px;border-radius:18px;border:1px solid var(--line);background:var(--panel-strong);cursor:pointer;text-align:left;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.menu-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--brand)}.menu-card__icon{font-size:1.9rem}.menu-card__title{font-weight:600;color:var(--ink)}.menu-card__type{font-size:.82rem;color:var(--muted);text-transform:capitalize}.facturas-count{color:var(--muted);font-size:.9rem}.facturas-filtros{display:flex;align-items:flex-end;gap:12px;margin:16px 0 4px;flex-wrap:wrap}.filtro{display:flex;flex-direction:column;gap:4px}.filtro--grow{flex:1;min-width:180px}.filtro span{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.filtro select,.filtro input{padding:9px 12px;border-radius:12px;border:1px solid var(--line);background:var(--panel-strong);color:var(--ink);font-size:.92rem}.modal-backdrop--print{align-items:flex-start;overflow:auto;padding:24px}.comprobante-wrap{width:210mm;max-width:96vw;margin:0 auto;display:flex;flex-direction:column;gap:12px}.comprobante-toolbar{display:flex;justify-content:flex-end;gap:10px}.comprobante-doc{background:#fff;color:#1f2937;width:210mm;max-width:96vw;min-height:297mm;margin:0 auto;padding:18mm 16mm;box-sizing:border-box;box-shadow:var(--shadow);font-size:.86rem}.cmp-head{display:grid;grid-template-columns:1fr auto 1fr;gap:16px;align-items:start;border-bottom:2px solid #1f2937;padding-bottom:14px}.cmp-colegio{font-size:1.15rem;font-weight:700}.cmp-colegio-linea{font-size:.8rem;color:#4b5563}.cmp-head__letter{text-align:center;border:2px solid #1f2937;border-radius:6px;padding:4px 14px;align-self:center}.cmp-letter{font-size:1.9rem;font-weight:800;line-height:1}.cmp-cod{font-size:.68rem}.cmp-head__right{text-align:right}.cmp-tipo{font-size:1.1rem;font-weight:700;margin-bottom:6px}.cmp-kv{display:flex;justify-content:space-between;gap:10px;font-size:.82rem}.cmp-kv span{color:#6b7280}.cmp-kv strong{font-weight:600;text-align:right}.cmp-head__left .cmp-kv{justify-content:flex-start}.cmp-receptor{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:8px 28px;padding:14px 0;border-bottom:1px solid #d1d5db}.cmp-receptor__col{display:flex;flex-direction:column;gap:4px}.cmp-beca{position:absolute;top:8px;right:0;font-size:.72rem;font-weight:700;color:#6b7280;text-transform:uppercase}.cmp-detalle{width:100%;border-collapse:collapse;margin-top:14px}.cmp-detalle th,.cmp-detalle td{padding:6px 4px;text-align:left}.cmp-detalle th{font-size:.74rem;text-transform:uppercase;color:#6b7280;border-bottom:1px solid #d1d5db}.cmp-detalle td{border-bottom:1px dotted #e5e7eb}.cmp-detalle .num{text-align:right;font-variant-numeric:tabular-nums}.cmp-total-label{font-weight:700;text-align:right;padding-top:10px}.cmp-total{font-weight:800;padding-top:10px}.cmp-vence{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding:10px 14px;border:1px solid #1f2937;border-radius:6px;font-weight:600}.cmp-afip{display:flex;gap:18px;align-items:center;margin-top:20px;padding-top:16px;border-top:1px solid #d1d5db}.cmp-qr{width:120px;height:120px}.cmp-afip__data{flex:1}.cmp-afip__title{font-weight:700;margin-bottom:6px}.cmp-barra{font-family:Courier New,monospace;letter-spacing:2px;font-size:.8rem;margin:6px 0;word-break:break-all}.cmp-afip__legal{font-size:.7rem;color:#6b7280}.cmp-pie{margin-top:16px;font-size:.74rem;color:#6b7280;display:flex;flex-direction:column;gap:2px}@media (max-width: 640px){.cmp-head{grid-template-columns:1fr}.cmp-head__right{text-align:left}.cmp-receptor{grid-template-columns:1fr}.comprobante-doc{padding:18px}}@media print{body *{visibility:hidden}#comprobante-print,#comprobante-print *{visibility:visible}#comprobante-print{position:absolute;left:0;top:0;width:100%;box-shadow:none;border-radius:0;padding:0}.no-print{display:none!important}}.logout-button{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:999px;border:1px solid var(--brand);background:var(--brand);color:#fff;font-weight:700;font-size:.88rem;cursor:pointer;white-space:nowrap;transition:background .15s ease,border-color .15s ease}.logout-button:hover{background:var(--brand-dark);border-color:var(--brand-dark)}.logout-button span{font-size:1rem;line-height:1}.ctacte-stats{display:flex;gap:12px;flex-wrap:wrap;margin:14px 0 4px}.stat-pill{display:flex;flex-direction:column;gap:2px;padding:12px 18px;border-radius:14px;border:1px solid var(--line);background:var(--panel-strong);min-width:140px}.stat-pill span{font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.stat-pill strong{font-size:1.15rem;font-variant-numeric:tabular-nums}.stat-pill--debe strong{color:var(--brand-dark)}.stat-pill--ok strong{color:var(--success)}.num--haber{color:var(--error)}.ctacte-nota{margin-top:12px;font-size:.78rem;color:var(--muted)}.deuda-total-card{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin:16px 0;padding:20px 24px;border-radius:18px;border:1px solid var(--line);background:linear-gradient(135deg,#b453091a,#2563eb0f)}.deuda-total{font-size:2rem;font-weight:800;color:var(--brand-dark);line-height:1.1}.deuda-total__sub{font-size:.82rem;color:var(--muted);margin-top:4px}.primary-button--pay{width:auto;margin:0;padding:12px 26px;border-radius:999px;border:none;font-weight:700;cursor:pointer}.deuda-ok{margin-top:18px;padding:28px;text-align:center;font-size:1.05rem;color:var(--success);border:1px solid rgba(22,101,52,.25);background:#1665340f;border-radius:18px}.portal-burger{display:inline-flex;flex-direction:column;justify-content:center;gap:4px;width:38px;height:38px;padding:9px;border:1px solid var(--line);border-radius:10px;background:transparent;cursor:pointer}.portal-burger span{display:block;height:2px;width:100%;background:var(--ink);border-radius:2px}.portal-drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;z-index:200;display:flex;animation:portalFade .12s ease}.portal-drawer{width:270px;max-width:82vw;height:100%;background:#fff;box-shadow:6px 0 30px #0f172a33;padding:16px 12px;display:flex;flex-direction:column;gap:4px;animation:portalDrawerIn .18s ease}.portal-drawer__head{display:flex;align-items:center;justify-content:space-between;padding:4px 10px 12px;font-weight:700;color:var(--ink);border-bottom:1px solid var(--line);margin-bottom:6px}.portal-drawer__close{border:none;background:transparent;font-size:1.5rem;line-height:1;color:var(--muted);cursor:pointer}.portal-drawer__item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 14px;border:none;border-radius:10px;background:transparent;color:var(--ink);font-size:1rem;text-align:left;cursor:pointer;transition:background .15s ease,color .15s ease}.portal-drawer__item:hover{background:var(--panel)}.portal-drawer__item.is-active{background:var(--brand);color:#fff;font-weight:600}.portal-drawer__icon{font-size:1.2rem}@keyframes portalFade{0%{opacity:0}to{opacity:1}}@keyframes portalDrawerIn{0%{transform:translate(-100%)}to{transform:translate(0)}}@media (max-width: 600px){.portal-topbar{padding:12px 16px}.portal-topbar__name{display:none}.portal-main--minimal{padding:18px 14px 40px}}
