@import "https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500;600;700&family=DM+Sans:wght@400;500;600;700&display=swap";:root{--gold:#b8960c;--gold-light:#d4ac0e;--gold-soft:#b8960c1f;--ink:#1a1a1a;--ink-soft:#4a4a4a;--ink-mute:#8a8a8a;--bg:#f4f3ef;--card:#fff;--line:#e4e2dc;--sidebar:#0a0a0a;--sidebar-soft:#161616;--sidebar-line:#ffffff14;--danger:#c0392b;--ok:#2e7d32;--radius:10px;--shadow:0 1px 3px #0000000f, 0 6px 20px #0000000d;--sans:"DM Sans", system-ui, "Segoe UI", sans-serif;--serif:"Playfair Display", Georgia, serif;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--sans);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:15px;line-height:1.6}h1,h2,h3{font-family:var(--serif);color:var(--ink);font-weight:600;line-height:1.25}h1{font-size:1.75rem}h2{font-size:1.3rem}h3{font-size:1.1rem}a{color:inherit;text-decoration:none}p{margin:0}.layout{min-height:100%;display:flex}.sidebar{background:var(--sidebar);color:#fff;z-index:40;flex-direction:column;flex-shrink:0;width:232px;display:flex;position:fixed;inset:0 auto 0 0}.sidebar-brand{border-bottom:1px solid var(--sidebar-line);align-items:center;gap:.65rem;padding:1.4rem 1.25rem;display:flex}.brand-mark{background:var(--gold);color:#000;width:34px;height:34px;font-family:var(--serif);border-radius:7px;justify-content:center;align-items:center;font-size:.95rem;font-weight:700;display:flex}.brand-name{font-family:var(--serif);letter-spacing:.01em;font-size:1.05rem;font-weight:600}.sidebar-nav{flex-direction:column;flex:1;gap:.15rem;padding:.9rem .65rem;display:flex}.nav-link{color:#fff9;border-left:2px solid #0000;border-radius:7px;align-items:center;padding:.62rem .85rem;font-size:.86rem;font-weight:500;transition:background .18s,color .18s;display:flex}.nav-link:hover{background:var(--sidebar-soft);color:#ffffffe6}.nav-link.is-active{background:var(--sidebar-soft);color:var(--gold-light);border-left-color:var(--gold)}.sidebar-foot{border-top:1px solid var(--sidebar-line);padding:1rem 1.25rem}.sidebar-role{letter-spacing:.16em;text-transform:uppercase;color:#ffffff59;font-size:.66rem;font-weight:700}.sidebar-backdrop{display:none}.layout-main{flex-direction:column;flex:1;min-width:0;margin-left:232px;display:flex}.topbar{background:var(--card);border-bottom:1px solid var(--line);z-index:30;justify-content:space-between;align-items:center;height:60px;padding:0 1.5rem;display:flex;position:sticky;top:0}.menu-btn{color:var(--ink);background:0 0;border:none;padding:.25rem .5rem;font-size:1.4rem;display:none}.topbar-right{align-items:center;gap:1rem;margin-left:auto;display:flex}.topbar-user{color:var(--ink-soft);font-size:.85rem;font-weight:600}.lang-switch{border:1px solid var(--line);border-radius:6px;display:flex;overflow:hidden}.lang-switch button{background:var(--card);color:var(--ink-mute);border:none;padding:.3rem .55rem;font-size:.72rem;font-weight:700}.lang-switch button.is-active{background:var(--gold);color:#000}.btn-logout{border:1px solid var(--line);color:var(--ink-soft);background:0 0;border-radius:6px;padding:.4rem .85rem;font-size:.78rem;font-weight:600;transition:border-color .18s,color .18s}.btn-logout:hover{border-color:var(--danger);color:var(--danger)}.content{flex:1;padding:1.75rem}.auth-page{color:#fff;background:#000 radial-gradient(circle at 50% 0,#b8960c14 0%,#0000 60%);justify-content:center;align-items:center;min-height:100%;padding:1.5rem;display:flex}.auth-card{background:#111;border:1px solid #ffffff1a;border-radius:14px;width:100%;max-width:380px;padding:2.25rem 2rem;position:relative;box-shadow:0 12px 40px #0009}.auth-brand{text-align:center;margin-bottom:1.6rem}.auth-brand-name{font-family:var(--serif);color:var(--gold);letter-spacing:.01em;font-size:1.5rem;font-style:italic;font-weight:400;line-height:1.1}.auth-brand-tag{letter-spacing:.22em;text-transform:uppercase;color:#fff6;margin-top:.4rem;font-size:.62rem;font-weight:700;display:block}.auth-card h1{font-family:var(--serif);color:#fff;text-align:center;margin-bottom:.35rem;font-size:1.35rem;font-style:italic;font-weight:500}.auth-card h1:after{content:"";background:var(--gold);width:32px;height:2px;margin:.65rem auto 1.4rem;display:block}.auth-card form{flex-direction:column;gap:.7rem;display:flex}.auth-card .form-group label{letter-spacing:.06em;text-transform:uppercase;color:#ffffff8c;margin-bottom:.35rem;font-size:.7rem;font-weight:600;display:block}.auth-card .form-group input{width:100%;font-size:.88rem;font-family:var(--sans);color:#fff;background:#ffffff0d;border:1px solid #ffffff1f;border-radius:8px;outline:none;padding:.7rem .95rem;transition:border-color .2s,background .2s}.auth-card .form-group input:focus{border-color:var(--gold);background:#ffffff12}.auth-card .form-group input::placeholder{color:#ffffff4d}.auth-card button[type=submit]{background:var(--gold);color:#000;letter-spacing:.06em;width:100%;font-size:.82rem;font-weight:700;font-family:var(--sans);cursor:pointer;border:none;border-radius:8px;margin-top:.5rem;padding:.8rem 1.2rem;transition:background .2s,transform .15s;box-shadow:0 4px 18px #b8960c59}.auth-card button[type=submit]:hover:not(:disabled){background:var(--gold-light);transform:translateY(-1px)}.auth-card button[type=submit]:disabled{opacity:.55;cursor:not-allowed;transform:none}.auth-card .error-msg{color:#ff9b8f;background:#c0392b1f;border:1px solid #c0392b59;border-radius:7px;margin-bottom:.9rem;padding:.55rem .8rem;font-size:.78rem;font-weight:600}.auth-back{text-align:center;letter-spacing:.06em;color:#ffffff73;margin-top:1.4rem;font-size:.74rem;text-decoration:none;transition:color .2s;display:block}.auth-back:hover{color:var(--gold)}.portal-page{max-width:1080px}.portal-page>h1{margin-bottom:1.25rem}.page-header,.section-header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.25rem;display:flex}.section-header h2,.section-header h1{margin:0}.section{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:1.25rem;padding:1.25rem 1.4rem}.section h2{margin-bottom:.9rem}button{background:var(--gold);color:#000;border:none;border-radius:7px;padding:.5rem 1rem;font-family:inherit;font-size:.82rem;font-weight:600;transition:background .18s,opacity .18s}button:hover{background:var(--gold-light)}button:disabled{opacity:.55;cursor:not-allowed}button.btn-danger{color:var(--danger);background:0 0;border:1px solid #c0392b59}button.btn-danger:hover{background:#c0392b14}.list-actions button,.form-actions button[type=button]{color:var(--ink-soft);border:1px solid var(--line);background:0 0}.list-actions button:hover,.form-actions button[type=button]:hover{background:var(--bg);border-color:var(--ink-mute)}.list-actions button:last-child:hover{border-color:var(--danger);color:var(--danger)}input,select,textarea{width:100%;color:var(--ink);background:var(--card);border:1px solid var(--line);border-radius:7px;padding:.5rem .7rem;font-family:inherit;font-size:.86rem;transition:border-color .18s,box-shadow .18s}input:focus,select:focus,textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-soft);outline:none}textarea{resize:vertical}label{letter-spacing:.04em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:.3rem;font-size:.72rem;font-weight:600;display:block}.profile-form,.upload-form,.inline-form{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:1.5rem;padding:1.4rem}.profile-form h2{margin-bottom:1rem}.form-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.form-group.full{grid-column:1/-1}.form-actions{gap:.6rem;margin-top:1.25rem;display:flex}.inline-form,.upload-form{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.inline-form input,.inline-form select,.inline-form textarea,.upload-form input,.upload-form select{flex:160px;width:auto}.filters{flex-wrap:wrap;gap:.6rem;margin-bottom:1.25rem;display:flex}.filters select,.filters input{flex:0 240px;width:auto}.list{flex-direction:column;gap:.5rem;display:flex}.list-item{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);flex-wrap:wrap;align-items:center;gap:.85rem;padding:.85rem 1.1rem;transition:border-color .18s;display:flex}a.list-item:hover{border-color:var(--gold)}.list-item strong{font-size:.9rem;font-weight:600}.list-item span{color:var(--ink-mute);font-size:.82rem}.list-item p{color:var(--ink-soft);flex-basis:100%;font-size:.82rem}.list-actions{gap:.4rem;margin-left:auto;display:flex}.tag{letter-spacing:.05em;text-transform:uppercase;background:var(--gold-soft);border-radius:5px;padding:.2rem .5rem;font-weight:700;color:var(--gold)!important;font-size:.66rem!important}.detail-list{grid-template-columns:max-content 1fr;gap:.5rem 1.25rem;display:grid}.detail-list dt{letter-spacing:.04em;text-transform:uppercase;color:var(--ink-mute);align-self:center;font-size:.72rem;font-weight:700}.detail-list dd{color:var(--ink);font-size:.88rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.stat-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:.25rem;padding:1.4rem;display:flex}.stat-value{font-family:var(--serif);color:var(--ink);font-size:2.1rem;font-weight:700;line-height:1}.stat-label{letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mute);font-size:.74rem;font-weight:600}.portal-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;display:grid}.portal-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);text-align:center;flex-direction:column;align-items:center;gap:.6rem;padding:1.75rem 1rem;font-size:.88rem;font-weight:600;transition:border-color .18s,transform .18s;display:flex}.portal-card:hover{border-color:var(--gold);transform:translateY(-2px)}.portal-card-icon{font-size:1.85rem}.role-badge,.estado-badge{letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;border-radius:999px;padding:.22rem .55rem;font-size:.68rem;font-weight:700}.role-admin{background:var(--gold-soft);color:#8a6f08}.role-asistente{color:#2a4678;background:#2846781f}.role-client{color:var(--ink-soft);background:#0000000f}.estado-pendiente{color:#8a6f08;background:#c8960024}.estado-confirmada{color:var(--ok);background:#2e7d3221}.estado-cancelada{color:var(--danger);background:#c0392b1f}.estado-completada{color:var(--ink-soft);background:#0000000f}.error-msg,.success-msg{border-radius:7px;margin-bottom:1rem;padding:.6rem .85rem;font-size:.82rem;font-weight:600}.error-msg{color:var(--danger);background:#c0392b14;border:1px solid #c0392b40}.success-msg{color:var(--ok);background:#2e7d3214;border:1px solid #2e7d3240}.field-error{color:var(--danger);margin-top:.25rem;font-size:.74rem;display:block}.loading-screen{min-height:100vh;color:var(--ink-mute);justify-content:center;align-items:center;font-size:.9rem;display:flex}@media (width<=767px){.sidebar{transition:transform .25s;transform:translate(-100%);box-shadow:0 0 40px #00000080}.sidebar.is-open{transform:translate(0)}.sidebar-backdrop{z-index:35;background:#00000080;display:block;position:fixed;inset:0}.layout-main{margin-left:0}.menu-btn{display:block}.content{padding:1.1rem}.form-grid{grid-template-columns:1fr}.topbar-user{display:none}}
