/* Breso — Design system Apple-style */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
    --bg:#fbfbfd;
    --bg-soft:#f5f5f7;
    --surface:#ffffff;
    --surface-muted:#f5f5f7;
    --nav-bg:#1d1d1f;
    --nav-bg-soft:#2d2d2f;
    --nav-text:rgba(255,255,255,0.72);
    --nav-text-active:#ffffff;
    --text:#1d1d1f;
    --text-secondary:#6e6e73;
    --text-tertiary:#86868b;
    --border:rgba(0,0,0,0.08);
    --border-soft:rgba(0,0,0,0.05);
    --accent:#1d1d1f;
    --accent-hover:#424245;
    --apple-blue:#0071e3;
    --apple-blue-hover:#0077ed;
    --apple-blue-soft:rgba(0,113,227,0.10);
    --gold:#a69074;
    --gold-bright:#c4b49a;
    --gold-soft:rgba(166,144,116,0.12);
    --gold-muted:#d4c4ae;
    --success:#248a3d;
    --success-soft:rgba(36,138,61,0.10);
    --warn:#bf4800;
    --warn-soft:rgba(191,72,0,0.10);
    --danger:#d70015;
    --danger-soft:rgba(215,0,21,0.08);
    --radius:12px;
    --radius-lg:18px;
    --radius-sm:10px;
    --radius-pill:980px;
    --shadow-xs:0 1px 3px rgba(0,0,0,0.04);
    --shadow-sm:0 4px 24px rgba(0,0,0,0.06);
    --shadow-md:0 12px 48px rgba(0,0,0,0.10);
    --shadow-nav:2px 0 32px rgba(0,0,0,0.22);
    --nav-h:44px;
    --ease:cubic-bezier(0.25,0.1,0.25,1);
    --font-ui:-apple-system,BlinkMacSystemFont,"SF Pro Text","Segoe UI",Roboto,Helvetica,Arial,sans-serif;
    --font-display:"Instrument Serif",-apple-system,BlinkMacSystemFont,"SF Pro Display","Segoe UI",sans-serif;
}

html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}
body{
    font-family:var(--font-ui);
    background:var(--bg);
    color:var(--text);
    min-height:100vh;
    line-height:1.47059;
    letter-spacing:-0.022em;
    font-size:17px;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

::selection{background:var(--apple-blue-soft);color:var(--text)}
:focus{outline:none}
:focus-visible{
    outline:2px solid var(--apple-blue);
    outline-offset:2px;
}
.btn-primary:focus-visible,
.btn-secondary:focus-visible,
.btn-ghost:focus-visible,
.apple-globalnav-toggle:focus-visible,
.btn-mini:focus-visible,
.panel-doc-section > summary:focus-visible,
.picker-item:focus-visible{
    outline-offset:3px;
}
.apple-globalnav-link:focus-visible{border-radius:6px}
.btn-primary:focus-visible{border-radius:var(--radius-pill)}
.panel-doc-section > summary:focus-visible{border-radius:var(--radius-lg) var(--radius-lg) 0 0}

@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* ── LOGIN ── */
.login-page,
body.login-body{
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:32px 24px;
    background:var(--bg-soft);
}
.login-wrap{width:100%;max-width:400px;margin:0 auto;animation:fadeUp .8s var(--ease) both}
.login-card{
    width:100%;
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:var(--radius-lg);
    padding:48px 44px 44px;
    box-shadow:var(--shadow-sm);
}
.logo-area{text-align:center;margin-bottom:28px}
.logo-area img,
.login-logo,
.breso-logo-login{
    height:76px;width:auto;max-width:180px;
    object-fit:contain;object-position:center;
    margin:0 auto 22px;display:block;
}
.breso-logo-nav,
.apple-globalnav-brand img{
    height:34px;width:auto;max-width:96px;
    object-fit:contain;object-position:left center;
    border-radius:4px;flex-shrink:0;
}
.logo-area h1,
.login-title{
    font-family:var(--font-display);font-size:32px;font-weight:400;
    letter-spacing:-0.03em;margin-bottom:8px;color:var(--text);text-align:center;
}
.logo-area p,
.login-sub{font-size:14px;color:var(--text-secondary);text-align:center;margin-bottom:0;line-height:1.5}
.login-sub{margin-bottom:36px}
.divider{width:32px;height:1px;background:var(--gold);margin:20px auto 0;opacity:.7}
.login-badge-wrap{text-align:center}
.login-badge{
    display:inline-flex;align-items:center;gap:6px;
    margin:0 auto 32px;padding:7px 16px;
    background:var(--gold-soft);color:var(--gold);
    font-size:12px;font-weight:600;border-radius:var(--radius-pill);
}

/* ── APPLE GLOBAL NAV (como apple.com) ── */
.apple-globalnav-overlay{
    display:none;position:fixed;inset:0;background:rgba(0,0,0,0.32);z-index:9998;
    opacity:0;transition:opacity .3s var(--ease);
}
.apple-globalnav-overlay.open{display:block;opacity:1}

.apple-globalnav{
    position:fixed;top:0;left:0;right:0;z-index:9999;
    background:rgba(251,251,253,0.72);
    backdrop-filter:saturate(180%) blur(20px);
    -webkit-backdrop-filter:saturate(180%) blur(20px);
    border-bottom:1px solid rgba(0,0,0,0.08);
}
.apple-globalnav-inner{
    max-width:1024px;margin:0 auto;height:var(--nav-h);
    display:flex;align-items:center;gap:8px;padding:0 max(22px,env(safe-area-inset-right)) 0 max(22px,env(safe-area-inset-left));
}
.apple-globalnav-brand{
    display:inline-flex;align-items:center;gap:8px;
    font-size:17px;font-weight:600;letter-spacing:-0.022em;color:var(--text);
    flex-shrink:0;margin-right:8px;
}

.apple-globalnav-menu{
    display:flex;align-items:center;justify-content:center;
    flex:1;gap:2px;min-width:0;flex-wrap:nowrap;
}
.apple-globalnav-actions{
    display:flex;align-items:center;gap:4px;flex-shrink:0;
}
.apple-globalnav-user{
    font-size:12px;color:var(--text-tertiary);font-variant-numeric:tabular-nums;
    padding:0 8px;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}

.apple-globalnav-link{
    display:inline-flex;align-items:center;gap:4px;
    padding:0 10px;height:var(--nav-h);
    font-size:12px;line-height:1;font-weight:400;letter-spacing:-0.01em;
    color:var(--text) !important;text-decoration:none !important;
    opacity:.88;white-space:nowrap;
    transition:opacity .2s var(--ease);
}
.apple-globalnav-link:hover{opacity:1}
.apple-globalnav-link.active{opacity:1;font-weight:500}
.apple-globalnav-link-muted{opacity:.56}
.apple-globalnav-link-muted:hover{opacity:.88}

.apple-nav-badge{
    display:inline-flex;align-items:center;justify-content:center;
    min-width:16px;height:16px;padding:0 4px;border-radius:980px;
    font-size:9px;font-weight:700;line-height:1;
    background:rgba(0,0,0,0.08);color:var(--text-secondary);
}
.apple-nav-badge.alert{background:var(--danger);color:#fff}

.apple-globalnav-toggle{
    display:none;width:44px;height:44px;margin-left:auto;
    border:none;background:transparent;cursor:pointer;padding:0;
    flex-direction:column;align-items:center;justify-content:center;gap:5px;
}
.apple-globalnav-toggle span{
    display:block;width:17px;height:1px;background:var(--text);border-radius:1px;
    transition:transform .28s var(--ease),opacity .2s var(--ease);
}
.apple-globalnav.open .apple-globalnav-toggle span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.apple-globalnav.open .apple-globalnav-toggle span:nth-child(2){opacity:0;transform:scaleX(0)}
.apple-globalnav.open .apple-globalnav-toggle span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

.apple-globalnav-mobile{display:none}
.apple-globalnav-mobile-menu{
    display:flex;flex-direction:column;padding:8px 0 16px;
    border-top:1px solid var(--border-soft);
}
.apple-globalnav-mobile-menu .apple-globalnav-link{
    height:auto;padding:14px 22px;font-size:17px;opacity:1;
}
.apple-globalnav.open .apple-globalnav-mobile-menu .apple-globalnav-link{
    animation:navItemIn .38s var(--ease) both;
}
.apple-globalnav.open .apple-globalnav-mobile-menu .apple-globalnav-link:nth-child(1){animation-delay:.04s}
.apple-globalnav.open .apple-globalnav-mobile-menu .apple-globalnav-link:nth-child(2){animation-delay:.07s}
.apple-globalnav.open .apple-globalnav-mobile-menu .apple-globalnav-link:nth-child(3){animation-delay:.10s}
.apple-globalnav.open .apple-globalnav-mobile-menu .apple-globalnav-link:nth-child(4){animation-delay:.13s}
.apple-globalnav.open .apple-globalnav-mobile-menu .apple-globalnav-link:nth-child(5){animation-delay:.16s}
.apple-globalnav.open .apple-globalnav-mobile-menu .apple-globalnav-link:nth-child(6){animation-delay:.19s}
.apple-globalnav.open .apple-globalnav-mobile-menu .apple-globalnav-link:nth-child(7){animation-delay:.22s}
@keyframes navItemIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* Ocultar sidebar antiguo por si queda HTML viejo en caché */
.nav.admin-sidebar,.admin-nav-toggle,.nav-toggle.admin-nav-toggle{display:none !important}

/* ── SHELL ── */
.shell,
.shell-with-nav{
    margin-left:auto;margin-right:auto;
    max-width:1024px;
    padding:calc(var(--nav-h) + 48px) max(22px,env(safe-area-inset-right)) 80px max(22px,env(safe-area-inset-left));
    min-height:100vh;
}

/* ── HERO ── */
.hero{margin-bottom:40px;animation:fadeUp .55s var(--ease) both}
.hero-greet{
    font-size:12px;color:var(--text-tertiary);
    text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;
}
.hero-title{
    font-family:var(--font-display);
    font-size:clamp(40px,6vw,56px);
    font-weight:400;
    letter-spacing:-0.03em;
    line-height:1.05;
    margin-bottom:16px;
    color:var(--text);
}
.hero-desc{
    font-size:21px;color:var(--text-secondary);max-width:640px;
    line-height:1.381;font-weight:400;letter-spacing:.011em;
}

.stats{
    display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
    margin-bottom:36px;animation:fadeUp .6s var(--ease) .05s both;
}
.stat{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:var(--radius);
    padding:24px;
    box-shadow:var(--shadow-xs);
}
.stat:hover{box-shadow:var(--shadow-sm)}
.stat-label{
    font-size:11px;color:var(--text-tertiary);font-weight:600;
    text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;
}
.stat-value{
    font-family:var(--font-display);font-size:clamp(28px,3vw,40px);font-weight:400;
    letter-spacing:-0.03em;line-height:1;color:var(--text);
}
.stat-value.gold{color:var(--gold)}
.stat-value--compact{
    font-size:clamp(22px,2.5vw,28px);
    letter-spacing:-0.02em;
    padding-top:4px;
}

/* ── GRID & CARDS ── */
.grid{display:grid;grid-template-columns:1fr 360px;gap:24px;align-items:start}
.grid-main{animation:fadeUp .65s var(--ease) .1s both}
.grid-side{display:flex;flex-direction:column;gap:24px;animation:fadeUp .65s var(--ease) .15s both}

.card{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:var(--radius-lg);
    overflow:hidden;
    box-shadow:var(--shadow-xs);
}
.card:hover{box-shadow:var(--shadow-sm)}
.card-head{
    padding:18px 20px;border-bottom:1px solid var(--border-soft);
    background:var(--surface-muted);
}
.card-head-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.card-icon{
    width:40px;height:40px;border-radius:10px;
    background:var(--gold-soft);border:1px solid rgba(166,144,116,0.2);
    display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;
}
.card-icon-chart{font-size:0}
.card-icon-chart::before{
    content:"";
    width:18px;height:18px;
    background:center/contain no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23a69074' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 3v18h18'/%3E%3Cpath d='M7 16l4-5 4 3 5-7'/%3E%3C/svg%3E");
}
.card-head-text h2{font-size:18px;font-weight:600;letter-spacing:-0.01em;margin-bottom:4px}
.card-head-text p{font-size:14px;color:var(--text-secondary)}
.card-body{padding:24px 20px}

/* ── FORMS ── */
.field{margin-bottom:18px}
.field label{
    display:block;font-size:11px;font-weight:600;color:var(--text-tertiary);
    text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;
}
.field input[type=text],
.field input[type=email],
.field input[type=password],
.field select{
    width:100%;padding:13px 14px;font-family:inherit;font-size:15px;color:var(--text);
    background:var(--surface-muted);border:1px solid var(--border);border-radius:10px;
    outline:none;transition:border-color .2s,box-shadow .2s,background .2s;
    appearance:none;-webkit-appearance:none;
}
.field select{
    background-color:var(--surface-muted);
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238a8580' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;
}
.field input:focus,.field select:focus{
    background:var(--surface);border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-soft);
}
.field input::placeholder{color:#b0aaa4}
.field input:disabled,.field select:disabled{opacity:.5;cursor:not-allowed}

.drop-area{
    border:2px dashed var(--border);border-radius:var(--radius-lg);
    padding:40px 28px;text-align:center;cursor:pointer;
    background:var(--surface-muted);transition:border-color .2s,background .2s;
}
.drop-area:hover,.drop-area.drag{
    border-color:var(--gold);background:var(--gold-soft);
}
.drop-icon{
    width:48px;height:48px;margin:0 auto 14px;
    background:var(--surface);border:1px solid var(--border-soft);
    border-radius:12px;display:flex;align-items:center;justify-content:center;
    box-shadow:var(--shadow-xs);font-size:0;
}
.drop-icon::before{
    content:"";
    width:20px;height:20px;
    background:center/contain no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23a69074' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3v12M7 8l5-5 5 5'/%3E%3Cpath d='M5 21h14'/%3E%3C/svg%3E");
}
.drop-text{font-size:15px;font-weight:600;color:var(--text);margin-bottom:4px}
.drop-sub{font-size:13px;color:var(--text-tertiary)}
.drop-area input[type=file]{display:none}

/* ── BUTTONS ── */
.btn-primary{
    width:100%;padding:14px 22px;margin-top:8px;
    background:var(--apple-blue);color:#fff;border:none;border-radius:var(--radius-pill);
    font-family:inherit;font-size:17px;font-weight:400;letter-spacing:-0.022em;
    cursor:pointer;transition:background .2s var(--ease),transform .15s;
}
.btn-primary:hover{background:var(--apple-blue-hover);transform:scale(1.01)}
.btn-primary:active{transform:scale(0.99)}
.btn-primary:disabled{background:#d2d2d7;color:#86868b;cursor:not-allowed;transform:none}

.btn-secondary{
    width:100%;padding:13px 20px;margin-top:6px;
    background:var(--surface);color:var(--text);
    border:1px solid var(--border);border-radius:10px;
    font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;
    transition:background .2s,border-color .2s,transform .15s;
}
.btn-secondary:hover{background:var(--surface-muted);border-color:#ccc7bf;transform:translateY(-1px)}
.btn-secondary:active{transform:translateY(0)}

.btn-ghost{
    display:inline-flex;align-items:center;gap:6px;
    padding:9px 16px;font-size:13px;font-weight:600;
    color:var(--text-secondary);text-decoration:none;
    border-radius:var(--radius-pill);border:1px solid var(--border);background:var(--surface);
    cursor:pointer;font-family:inherit;transition:all .2s;
}
.btn-ghost:hover{background:var(--surface-muted);color:var(--text);border-color:#ccc7bf}
.btn-ghost.danger:hover{background:var(--danger-soft);color:var(--danger);border-color:rgba(180,35,24,0.2)}

/* ── MESSAGES ── */
.msg{
    padding:12px 14px;border-radius:10px;font-size:13px;
    line-height:1.5;margin-bottom:18px;
}
.msg.ok{
    background:var(--success-soft);color:var(--success);
    border:1px solid rgba(31,122,77,0.12);
}
.msg.warn{
    background:var(--warn-soft);color:var(--warn);
    border:1px solid rgba(154,103,0,0.12);
}
.msg.err{
    background:var(--danger-soft);color:var(--danger);
    border:1px solid rgba(180,35,24,0.12);
}
.error-msg{
    background:var(--danger-soft);color:var(--danger);padding:12px 14px;
    border-radius:10px;font-size:13px;margin-bottom:18px;line-height:1.5;
    border:1px solid rgba(180,35,24,0.12);
}
.footer-note{text-align:center;margin-top:28px;font-size:12px;color:var(--text-tertiary);line-height:1.6}
.login-back{
    color:var(--text-tertiary);text-decoration:none;margin-top:10px;display:inline-block;
    font-weight:500;transition:color .2s;
}
.login-back:hover{color:var(--gold)}
.login-forgot{text-align:center;margin:14px 0 0}
.login-forgot .login-back{font-size:14px;margin-top:0}

.creds-box{
    background:var(--surface-muted);border:1px solid var(--border-soft);
    border-radius:var(--radius-sm);padding:20px 22px;margin-bottom:22px;
    font-size:14px;line-height:1.8;
}
.creds-box strong{font-weight:600}
.creds-box code{
    background:var(--surface);padding:3px 8px;border-radius:6px;
    font-size:13px;border:1px solid var(--border);
    font-family:ui-monospace,"SF Mono",Consolas,monospace;
}
.creds-hint{margin-top:12px;font-size:12px;color:var(--text-secondary)}

.portal-card-alquiler,.portal-card-contacto{margin-bottom:20px}
.portal-muted{font-size:14px;color:var(--text-secondary);line-height:1.55;margin:0}
.portal-alquiler-item{padding:0}
.portal-alquiler-item-sep{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-soft)}
.portal-alquiler-tipo{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);margin:0 0 4px}
.portal-alquiler-plaza{font-size:17px;margin:0 0 6px;color:var(--text)}
.portal-alquiler-meta{font-size:14px;color:var(--text-secondary);margin:0 0 4px;line-height:1.45}
.portal-alquiler-meta strong{color:var(--text);font-weight:600}
.portal-alquiler-mes{font-size:12px;color:var(--text-tertiary);margin:8px 0 0}
.portal-alquiler-foot{margin-top:16px;padding-top:14px}
.portal-alquiler-actualizado{font-size:12px;color:var(--text-secondary);margin:0;line-height:1.45}
.portal-alquiler-actualizado-solo{margin-top:14px}
.portal-alquiler-actualizado strong{color:var(--text);font-weight:600}
.portal-alquiler-hint{font-size:12px;color:var(--text-tertiary);margin:0;line-height:1.5}
.portal-alquiler-foot .portal-alquiler-hint{margin:0 0 10px;color:var(--text-secondary)}
.portal-alquiler-foot .portal-alquiler-actualizado{margin:0}
.portal-alquiler-precios{
    display:flex;flex-wrap:wrap;gap:8px 14px;margin-top:8px;font-size:13px;color:var(--text-secondary);
    font-variant-numeric:tabular-nums;
}
.portal-alquiler-precios .portal-alquiler-total{color:var(--text);font-weight:600}
.portal-contact-body{font-size:14px;line-height:1.55}
.portal-contact-line{margin:0 0 14px;color:var(--text-secondary)}
.portal-contact-line:last-child{margin-bottom:0}
.portal-contact-line strong{color:var(--text);font-weight:600}
.portal-contact-line a{color:var(--accent,#0071e3);text-decoration:none;font-weight:500}
.portal-contact-line a:hover{text-decoration:underline}

.preview-banner{
    background:var(--accent);color:#fff;text-align:center;
    padding:12px 20px;font-size:13px;font-weight:600;letter-spacing:.01em;
}

/* ── CLIENT LIST & MANAGEMENT ── */
.is-hidden{display:none !important}
.client-list-wrap{padding-top:0}
.client-list{
    max-height:360px;overflow-y:auto;
    border:1px solid var(--border);border-radius:var(--radius-sm);
    background:var(--surface);
}
.client-list-wide{max-height:420px}
.client-list::-webkit-scrollbar{width:6px}
.client-list::-webkit-scrollbar-thumb{background:rgba(20,20,19,0.12);border-radius:3px}
.client-item{
    display:grid;grid-template-columns:40px 1fr auto auto auto;align-items:center;gap:12px;
    padding:12px 16px;border-bottom:1px solid var(--border-soft);
}
.client-item:last-child{border-bottom:none}
.client-item:hover{background:var(--gold-soft)}
.client-main{min-width:0}
.client-avatar{
    width:40px;height:40px;border-radius:50%;
    background:var(--gold);color:#fff;font-size:15px;font-weight:600;
    display:flex;align-items:center;justify-content:center;
}
.client-name{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.client-cif{font-size:12px;color:var(--text-tertiary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.client-docs{
    font-size:12px;font-weight:600;color:var(--text-secondary);
    background:var(--surface-muted);padding:5px 10px;border-radius:var(--radius-pill);white-space:nowrap;
}
.client-list-empty{padding:0;border:none;background:transparent}
.breso-empty-state{
    padding:36px 24px;text-align:center;
    background:linear-gradient(180deg,var(--surface-muted),var(--surface));
    border:1px dashed var(--border);border-radius:var(--radius);
}
.breso-empty-icon{
    width:52px;height:52px;margin:0 auto 16px;border-radius:50%;
    background:var(--gold-soft);border:1px solid rgba(166,144,116,0.18);
    display:flex;align-items:center;justify-content:center;
}
.breso-empty-icon::before{
    content:"";
    width:22px;height:22px;opacity:.72;
    background:center/contain no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23a69074' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z'/%3E%3Cpath d='M14 2v6h6M9 13h6M9 17h4'/%3E%3C/svg%3E");
}
.breso-empty-title{
    font-size:15px;font-weight:600;color:var(--text);margin-bottom:6px;letter-spacing:-0.01em;
}
.breso-empty-desc{font-size:13px;color:var(--text-tertiary);line-height:1.5;max-width:280px;margin:0 auto}
.picker-empty{
    padding:28px 20px;text-align:center;color:var(--text-tertiary);font-size:13px;line-height:1.5;
    background:var(--surface-muted);border-radius:var(--radius-sm);
}
.client-cat-form,.client-del-form{display:flex;align-items:center;gap:6px}
.cat-select{
    max-width:130px;padding:7px 28px 7px 10px;font-family:inherit;font-size:12px;
    border:1px solid var(--border);border-radius:8px;background:var(--surface-muted);color:var(--text);
    appearance:none;-webkit-appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%238a8580' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 8px center;
}
.btn-mini{
    width:32px;height:32px;border:1px solid var(--border);border-radius:8px;
    background:var(--surface);font-size:0;cursor:pointer;font-family:inherit;
    display:inline-flex;align-items:center;justify-content:center;transition:all .15s;color:transparent;
}
.btn-mini:hover{background:var(--surface-muted)}
.btn-mini-save::before{
    content:"";
    width:14px;height:14px;
    background:center/contain no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23248a3d' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");
}
.btn-mini.danger::before{
    content:"";
    width:12px;height:12px;
    background:center/contain no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23d70015' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 6L6 18M6 6l12 12'/%3E%3C/svg%3E");
}
.btn-mini.danger:hover{background:var(--danger-soft);border-color:rgba(215,0,21,.25)}

.cat-badge{
    font-size:11px;font-weight:600;padding:3px 9px;border-radius:var(--radius-pill);white-space:nowrap;
}
.cat-general{background:var(--surface-muted);color:var(--text-secondary)}
.cat-local{background:var(--gold-soft);color:var(--gold)}
.cat-garaje{background:var(--warn-soft);color:var(--warn)}

.manage-section{margin-top:28px}
.menuem-section{margin-bottom:28px}
.menuem-upload{margin-bottom:20px}
.menuem-upload-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.menuem-upload-row input[type=file]{flex:1;min-width:220px;font-size:13px}
.menuem-btn{width:auto;min-width:180px;padding:12px 20px}
.menuem-stats{margin-top:8px;margin-bottom:20px}
.menuem-shell-wide{max-width:98%;width:100%;max-width:1600px}
.menuem-garaje-table{table-layout:fixed;width:100%;min-width:1040px}
.menuem-garaje-table .menuem-col-plaza{width:72px;min-width:72px;max-width:72px}
.menuem-garaje-table .menuem-col-nombre{width:28%;min-width:180px}
.menuem-garaje-table .menuem-col-tel{width:120px;min-width:120px;max-width:120px}
.menuem-garaje-table .menuem-col-dir{width:22%;min-width:160px}
.menuem-garaje-table .menuem-col-base{width:88px;min-width:88px}
.menuem-garaje-table .menuem-col-iva{width:84px;min-width:84px}
.menuem-garaje-table .menuem-col-total{width:96px;min-width:96px}
.menuem-garaje-table .menuem-col-ocup{width:52px;min-width:52px}
.menuem-garaje-table .menuem-col-del{width:44px;min-width:44px}
.menuem-garaje-table td,.menuem-garaje-table th{white-space:normal;vertical-align:middle}
.menuem-garaje-table .menuem-in-plaza{max-width:100%;min-width:0;text-align:center;padding:8px 4px}
.menuem-garaje-table .menuem-in-nombre{max-width:100%;min-width:0;width:100%}
.menuem-garaje-table .menuem-in-telefono{max-width:100%;min-width:0;width:100%;font-size:12px;padding:8px 6px}
.menuem-garaje-table .menuem-in-direccion{max-width:100%;min-width:0;width:100%;font-size:12px;padding:8px 6px}
.menuem-garaje-table .menuem-in-base{max-width:100%;min-width:0;width:100%;text-align:right;padding:8px 6px}
.menuem-table-wrap-garaje{overflow-x:auto}
.menuem-block-garaje[open] .menuem-table-wrap-garaje{overflow:visible;max-height:none}
.menuem-block-head-card{margin-bottom:20px}
.abm-titulos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px 16px}
.abm-w-chk-group{width:72px}
.abm-table col.abm-w-chk-group{width:72px!important;min-width:72px!important;max-width:72px!important}
.abm-col-chk-group,.abm-th-chk-group{
    width:72px!important;min-width:72px!important;max-width:72px!important;
    padding:0!important;vertical-align:stretch;height:1px;text-align:center;
    border-right:1px solid var(--border-soft,var(--border));
}
.abm-chk-group,.abm-chk-group-head{
    display:grid;grid-template-columns:repeat(3,1fr);position:relative;
    width:100%;height:100%;min-height:100%;margin:0;
    align-items:center;justify-items:center;
}
.abm-chk-group::before,.abm-chk-group::after,
.abm-chk-group-head::before,.abm-chk-group-head::after{
    content:'';position:absolute;top:0;bottom:0;width:1px;
    background:var(--border-soft,var(--border));pointer-events:none;z-index:0;
}
.abm-chk-group::before,.abm-chk-group-head::before{left:33.3333%}
.abm-chk-group::after,.abm-chk-group-head::after{left:66.6666%}
.abm-th-chk-group .abm-chk-group-head{min-height:36px}
.abm-col-chk-group .abm-chk-group{min-height:36px}
.abm-chk-group-head span,
.abm-chk-group .abm-chk{
    position:relative;z-index:2;
    display:flex;align-items:center;justify-content:center;
    border-right:none;min-height:unset;height:auto;
}
.abm-chk-group .abm-chk{
    flex:none;width:18px;height:18px;
    border:1px solid rgba(0,0,0,.14);border-radius:5px;
    background:linear-gradient(180deg,#fff 0%,#f4f4f6 100%);
    box-shadow:0 1px 2px rgba(0,0,0,.06),inset 0 1px 0 rgba(255,255,255,.95);
}
.abm-chk-group .abm-chk:hover{
    border-color:rgba(0,113,227,.45);
    box-shadow:0 1px 3px rgba(0,113,227,.12),inset 0 1px 0 rgba(255,255,255,.95);
}
.abm-chk-group .abm-chk.is-on{
    color:var(--text,#1d1d1f);
    border-color:rgba(0,0,0,.22);
    background:linear-gradient(180deg,#f8f8fa 0%,#ececf0 100%);
    box-shadow:inset 0 1px 2px rgba(0,0,0,.06);
}
.abm-chk-group-head span{
    text-align:center;font-size:11px;font-weight:700;line-height:1;letter-spacing:.02em;
}
.abm-table-bajas{width:100%;table-layout:fixed}
.abm-table-bajas col.abm-w-chk-group{width:72px!important;max-width:72px!important}
.abm-table-bajas col.abm-w-destino{width:74px;min-width:74px;max-width:74px}
.abm-table-bajas col.abm-w-cliente-bajas{width:120px;min-width:120px;max-width:120px}
.abm-table-bajas .abm-in-cliente{max-width:120px;width:100%;font-size:12px}
.abm-table-bajas .abm-in-destino,
.abm-table-bajas select.abm-in-destino{font-size:11px;padding-left:2px;padding-right:1px}
.abm-table-bajas .abm-col-destino{max-width:74px;padding-left:6px;padding-right:4px}
.abm-table th.abm-th-num{text-align:right;padding-left:2px;padding-right:4px}
.abm-table td.abm-col-base{text-align:right!important;padding-right:4px!important}
.abm-table td.abm-col-calc,.abm-table td.menuem-calc.abm-col-calc{text-align:right!important;padding-right:4px!important}
.abm-chk{
    display:inline-flex;align-items:center;justify-content:center;
    width:20px;height:20px;border:1.5px solid var(--border);border-radius:4px;
    background:#fff;cursor:pointer;padding:0;font-family:inherit;color:transparent;
    transition:background .15s,border-color .15s,color .15s;
}
.abm-chk:hover{border-color:var(--accent,#0071e3)}
.abm-chk.is-on{color:var(--text,#1d1d1f);border-color:var(--text-secondary,#6e6e73);background:var(--surface-muted,#f5f5f7)}
.abm-chk-x{font-size:12px;line-height:1;font-weight:700;pointer-events:none}
.abm-chk:not(.is-on) .abm-chk-x{visibility:hidden}
.abm-table,.abm-table-mod{table-layout:fixed;width:100%;border-collapse:separate;border-spacing:0}
.abm-table-mod{min-width:1140px}
.abm-table th,.abm-table td{white-space:normal;vertical-align:middle;padding:8px 5px}
.abm-table th.abm-th-destino,.abm-table th.abm-th-precio,.abm-table th.abm-th-plaza-nueva{
    white-space:normal;line-height:1.2;font-size:10px;text-align:center;padding-left:2px;padding-right:2px
}
.abm-table .abm-col-plaza{padding-right:16px;border-right:1px solid var(--border)}
.abm-table .abm-col-destino{padding-left:10px;padding-right:6px;background:var(--surface-muted);max-width:68px}
.abm-table .abm-col-cuenta{padding-right:4px}
.abm-table .abm-col-plaza-nueva{padding-left:2px;padding-right:8px}
.abm-table th.abm-th-destino{background:var(--surface-muted)}
.abm-table .abm-col-tipo{padding-right:4px}
.abm-table .abm-col-destino select.menuem-in{font-size:11px;padding-left:3px;padding-right:2px}
.abm-table .menuem-in,.abm-table select.menuem-in{max-width:100%;min-width:0;width:100%;font-size:12px;box-sizing:border-box}
.abm-w-plaza{width:54px}
.abm-w-destino{width:68px}
.abm-w-cliente{width:210px}
.abm-w-cliente-bajas{width:148px}
.abm-w-cliente-mod{width:232px}
.abm-w-dni{width:102px}
.abm-w-cuenta{width:220px}
.abm-w-plaza-nueva{width:46px}
.abm-w-precios-stack{width:72px}
.abm-w-base{width:62px}
.abm-w-calc{width:76px}
.abm-w-precio{width:74px}
.abm-w-dif{width:78px}
.abm-w-tipo{width:102px}
.abm-w-obs{width:132px}
.abm-w-del{width:34px}
.abm-table .abm-in-plaza{max-width:54px;text-align:center;padding-left:4px;padding-right:4px;font-size:12px}
.abm-table .abm-in-base,.abm-table .abm-in-precio-ant,.abm-table .abm-in-precio-nuevo{
    text-align:right;padding-left:3px;padding-right:3px;font-size:11px
}
.abm-precios-stack{display:flex;flex-direction:column;gap:3px}
.abm-precios-stack .menuem-in{max-width:72px;min-height:28px;padding-top:4px;padding-bottom:4px}
.abm-table .abm-in-dni{max-width:102px;font-size:12px}
.abm-table .abm-in-cuenta,.abm-table .abm-in-cuenta-mod{font-size:11px;letter-spacing:-.02em;font-family:ui-monospace,"SF Mono",Consolas,monospace;padding-left:5px;padding-right:5px}
.abm-table .abm-in-cliente{font-size:12px}
.abm-table .abm-in-tipo{font-size:11px;padding-left:4px;padding-right:2px}
.abm-table .abm-in-plaza-nueva{max-width:46px;text-align:center;padding-left:2px;padding-right:2px;font-size:12px}
.abm-table .abm-in-obs,.abm-table textarea.abm-in-obs{min-height:44px;resize:vertical;line-height:1.35;font-size:12px}
.abm-table .abm-col-calc,.abm-table .menuem-calc{font-size:12px;white-space:nowrap;padding-left:4px;padding-right:4px;text-align:right}
.abm-table .abm-col-dif,.abm-table .abm-calc-dif{font-size:11px;text-align:right;padding-left:3px;padding-right:3px}
.abm-table .abm-calc-dif strong{font-size:12px;font-weight:600}
.abm-dif-neg,.abm-table .abm-calc-dif .abm-dif-neg{color:var(--error,#c0392b)}
.abm-table .abm-calc-total strong{font-size:12px;font-weight:600}
.abm-table.abm-table-mod .menuem-edit-table .menuem-in-base,
.abm-table .abm-in-base{max-width:62px!important}
.abm-field-off .menuem-in,.abm-field-off textarea{
    opacity:.35;background:var(--surface-muted);border-color:var(--border-soft);color:var(--text-tertiary);cursor:default
}
.abm-field-off .menuem-in::placeholder,.abm-field-off textarea::placeholder{color:#c8c4bc}
.abm-field-off.menuem-calc,.abm-field-off.abm-col-dif{opacity:.35;color:var(--text-tertiary)}
.abm-table-wrap,.menuem-table-wrap-garaje{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}
.abm-total-hint{font-size:11px;font-weight:500;color:var(--text-secondary)}
.menuem-block[open] .menuem-table-wrap{max-height:none;overflow:visible}
.menuem-block-garaje[open] .menuem-table-wrap-garaje{max-height:none;overflow:visible}
.menuem-block[open]{margin-bottom:28px}
.menuem-block-head{
    display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;
    padding:14px 20px;border-bottom:1px solid var(--border);background:var(--surface-muted);
}
.menuem-field-titulo{flex:1;min-width:220px;max-width:420px;margin:0}
.menuem-field-titulo label{font-size:12px;color:var(--text-secondary);margin-bottom:6px;display:block}
.menuem-field-titulo .menuem-bloque-titulo{
    width:100%;border:1px solid var(--border);border-radius:10px;
    padding:10px 14px;font-size:14px;font-weight:600;font-family:inherit;background:var(--surface);
}
.menuem-block summary{
    display:flex;align-items:center;gap:8px;flex-wrap:wrap;
}
.menuem-summary-count{color:var(--text-secondary);font-weight:500;font-size:13px}
.menuem-pdf-btn{text-decoration:none;display:inline-flex;align-items:center;justify-content:center}
.menuem-block{
    border:1px solid var(--border);border-radius:var(--radius);
    margin-bottom:18px;overflow:hidden;
    background:var(--surface);box-shadow:var(--shadow-xs);
}
.menuem-block summary{
    padding:18px 22px;font-size:15px;font-weight:600;cursor:pointer;
    background:var(--surface-muted);
    border-bottom:1px solid var(--border-soft);list-style:none;
}
.menuem-edit-table thead th{
    background:var(--surface-muted);
    font-size:11px;letter-spacing:.04em;
}
.menuem-edit-table tbody tr:nth-child(even){background:var(--surface-muted)}
.menuem-calc{color:var(--text-secondary);font-variant-numeric:tabular-nums}
.menuem-calc-total{color:var(--text)}
.menuem-block summary::-webkit-details-marker{display:none}
.menuem-table-wrap{overflow-x:auto}
.menuem-block:not([open]) .menuem-table-wrap{max-height:320px;overflow-y:auto}
.menuem-table{width:100%;border-collapse:collapse;font-size:13px}
.menuem-garaje-table th,.menuem-garaje-table td{white-space:normal}
.menuem-table th,.menuem-table td{
    padding:10px 14px;text-align:left;border-bottom:1px solid var(--border-soft);white-space:nowrap;
}
.menuem-table th{
    position:sticky;top:0;background:var(--surface-muted);font-size:11px;text-transform:uppercase;
    letter-spacing:.04em;color:var(--text-secondary);font-weight:600;
}
.menuem-table tbody tr:hover{background:var(--surface-muted)}
.menuem-off{opacity:.45}
.menuem-link-card{margin-bottom:28px}
.admin-tool-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:28px}
.admin-tool-cards .menuem-link-card{margin-bottom:0}
.admin-logout-form{display:inline;margin:0;padding:0;border:0}
.admin-logout-form button.apple-globalnav-link{font:inherit;cursor:pointer;border:0;background:none;padding:0;text-align:inherit}
.menuem-link-body{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px}
.menuem-link-title{font-size:18px;font-weight:600;margin:0 0 6px}
.menuem-link-btn{width:auto;min-width:160px;padding:12px 24px;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}
.menuem-shell{padding-bottom:100px}
.menuem-empty-msg{margin-bottom:20px}
.menuem-toolbar{display:flex;flex-wrap:wrap;gap:20px;align-items:flex-end;justify-content:space-between}
.menuem-toolbar-fields{display:flex;flex-wrap:wrap;gap:16px;flex:1}
.menuem-field-mes{min-width:200px;flex:1}
.menuem-field-iva{max-width:100px}
.menuem-import-form{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.menuem-file-input{max-width:240px;font-size:13px}
.menuem-totals-card{margin-bottom:24px}
.menuem-totals-table .menuem-subtotal-row td{background:var(--surface-muted);font-weight:500}
.menuem-totals-table .menuem-grand-row td{background:var(--gold-soft);font-weight:600;border-top:2px solid var(--border)}
.menuem-totals-table .menuem-col-ref{width:96px;text-align:center;vertical-align:middle}
.menuem-totals-table .menuem-ref-altas{max-width:88px;text-align:center;padding:6px 8px;font-size:13px}
.menuem-block-head-inline{display:flex;flex-wrap:wrap;gap:16px 24px;align-items:flex-end;padding:14px 18px;border-bottom:1px solid var(--border-soft);background:var(--surface-muted)}
.menuem-field-ref{min-width:120px;max-width:160px}
.menuem-field-ref .menuem-in{max-width:120px;text-align:center}
.menuem-edit-table .menuem-in{
    width:100%;min-width:70px;border:1px solid var(--border);border-radius:8px;
    padding:8px 10px;font-size:13px;font-family:inherit;background:var(--surface);
}
.menuem-edit-table .menuem-in-base{max-width:110px;text-align:right}
.menuem-edit-table .menuem-in-num{max-width:60px}
.menuem-edit-table .menuem-col-dir{min-width:160px;width:22%}
.menuem-edit-table .menuem-in-direccion{max-width:100%;min-width:0;width:100%;font-size:12px}
.menuem-edit-table .menuem-check{text-align:center;width:48px}
.menuem-block-actions{padding:12px 18px 16px;border-top:1px solid var(--border-soft);background:var(--surface-muted)}
.menuem-savebar{
    position:fixed;left:50%;transform:translateX(-50%);bottom:16px;z-index:50;
    width:min(1024px,calc(100% - 44px));
    display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;
    padding:16px 24px;background:rgba(255,255,255,0.92);
    backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);
    border:1px solid var(--border);border-radius:var(--radius-lg);
    box-shadow:var(--shadow-md);
}
.menuem-savebar-hint{margin:0;font-size:13px;color:var(--text-secondary)}
.menuem-savebar .btn-primary{width:auto;min-width:180px;padding:12px 28px}

.manage-section[open] .manage-summary{margin-bottom:14px}
.manage-summary{
    list-style:none;cursor:pointer;padding:18px 22px;
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:var(--radius);display:flex;flex-direction:column;gap:6px;
    transition:border-color .2s,box-shadow .2s;
    box-shadow:var(--shadow-xs);
}
.manage-summary::-webkit-details-marker{display:none}
.manage-summary:hover{border-color:#ddd9d2;box-shadow:var(--shadow-sm)}
.manage-summary-title{font-size:17px;font-weight:600;letter-spacing:-.01em}
.manage-summary-meta{font-size:13px;color:var(--text-secondary)}
.manage-card{border-radius:var(--radius);overflow:hidden;margin-top:0;position:relative}
.gestion-toast{
    position:sticky;top:8px;z-index:10;
    padding:12px 16px;border-radius:var(--radius-sm);
    font-size:14px;font-weight:500;margin-bottom:14px;
    box-shadow:var(--shadow-sm);animation:fadeUp .25s var(--ease);
}
.gestion-toast.ok{background:var(--success-soft);color:var(--success);border:1px solid rgba(31,122,77,.25)}
.gestion-toast.err{background:var(--danger-soft);color:var(--danger);border:1px solid rgba(180,35,24,.2)}
.client-item.row-saved{background:var(--success-soft);transition:background .4s}
.manage-toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:14px}
.manage-toolbar .picker-filters{flex:1;min-width:200px}
.manage-toolbar .search-wrap{flex:1;min-width:220px;max-width:360px}

/* ── CLIENT PICKER ── */
.client-picker{position:relative}
.picker-box{background:var(--surface-muted);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px}
.picker-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.filter-pill{
    padding:7px 14px;border:1px solid transparent;border-radius:var(--radius-pill);
    background:transparent;font-family:inherit;font-size:13px;font-weight:500;
    color:var(--text-secondary);cursor:pointer;transition:all .15s;
}
.filter-pill:hover{background:var(--surface-muted);color:var(--text)}
.filter-pill.active{
    background:var(--surface);border-color:var(--border);color:var(--text);
    box-shadow:var(--shadow-xs);
}
.search-wrap{position:relative}
.search-icon{
    position:absolute;left:14px;top:50%;transform:translateY(-50%);
    color:var(--text-tertiary);pointer-events:none;z-index:1;
}
.field .search-wrap .picker-search,
.search-wrap .picker-search{
    width:100%;padding:12px 16px 12px 44px;font-family:inherit;font-size:15px;
    border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;
    background:var(--surface);transition:box-shadow .2s,border-color .2s;
}
.manage-toolbar .search-wrap .picker-search{
    padding:10px 14px 10px 40px;font-size:14px;background:var(--surface-muted);
}
.field .search-wrap .picker-search:focus,
.search-wrap .picker-search:focus{
    border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-soft);
}
.picker-hint{font-size:13px;color:var(--text-tertiary);margin-top:10px;line-height:1.5}
.picker-results{
    margin-top:10px;max-height:240px;overflow-y:auto;
    border:1px solid var(--border);border-radius:var(--radius-sm);
    background:var(--surface);box-shadow:var(--shadow-sm);
}
.picker-item{
    width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;text-align:left;
    padding:12px 16px;border:none;border-bottom:1px solid var(--border-soft);
    background:transparent;font-family:inherit;cursor:pointer;transition:background .12s;
}
.picker-item:last-child{border-bottom:none}
.picker-item:hover{background:var(--surface-muted)}
.picker-item-name{font-size:14px;font-weight:600;color:var(--text);min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.picker-item-meta{font-size:12px;color:var(--text-tertiary);flex-shrink:0}
.picker-selected{
    display:flex;align-items:center;justify-content:space-between;gap:14px;
    padding:14px 16px;background:var(--surface);border:1px solid var(--border);
    border-radius:var(--radius-sm);box-shadow:var(--shadow-xs);
}
.picker-selected-name{font-size:15px;font-weight:600;margin-bottom:4px;letter-spacing:-.01em}
.picker-selected-meta{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-tertiary)}
.picker-clear{
    padding:8px 14px;border:none;border-radius:8px;
    background:var(--surface-muted);font-family:inherit;font-size:13px;font-weight:500;
    color:var(--gold);cursor:pointer;white-space:nowrap;
}
.picker-clear:hover{background:var(--gold-soft)}

/* ── PORTAL CLIENTES ── */
.doc-panel-list{
    max-height:none;border:none;border-radius:0;background:transparent;
}
.doc-panel-item{
    grid-template-columns:40px minmax(0,1fr) auto !important;
    padding:14px 0 !important;
}
.doc-panel-item .client-name{
    white-space:normal;overflow:visible;word-break:break-word;line-height:1.35;
}
.doc-panel-item:hover{background:linear-gradient(90deg,var(--gold-soft),transparent) !important}
.doc-panel-item.is-new{
    background:linear-gradient(90deg,rgba(37,99,235,0.06),transparent) !important;
    border-left:3px solid var(--apple-blue);
}
.doc-panel-avatar{
    border-radius:11px !important;
    background:linear-gradient(145deg,var(--gold-bright),var(--gold)) !important;
    color:#fff !important;
    font-size:10px !important;
    font-weight:700 !important;
    letter-spacing:.05em;
    box-shadow:0 4px 12px rgba(166,144,116,0.25);
}
.doc-panel-actions{
    display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end;
}
.doc-panel-btn{width:auto;padding:9px 18px;margin-top:0;font-size:14px}
.panel-doc-section{margin-bottom:24px;transition:box-shadow .25s var(--ease)}
.panel-doc-section[open]{box-shadow:var(--shadow-xs)}
.panel-doc-section-has-new > summary{background:linear-gradient(180deg,rgba(37,99,235,0.05) 0%,var(--surface-muted) 100%)}
.panel-doc-section-has-new[open] > summary{border-bottom-color:rgba(37,99,235,0.12)}
.panel-doc-title{
    display:flex;align-items:center;flex-wrap:wrap;gap:10px;
    font-size:18px;font-weight:600;letter-spacing:-0.01em;margin-bottom:4px;
}
.panel-doc-title-text{line-height:1.25}
.panel-doc-title .badge-nuevo,
.panel-doc-section .card-head-text h2 .badge-nuevo{
    margin-left:0;font-family:var(--font-ui);font-size:9px;line-height:1.3;
    letter-spacing:.08em;text-transform:uppercase;flex-shrink:0;
}
.panel-doc-section > summary{
    list-style:none;
    cursor:pointer;
    user-select:none;
    padding:18px 20px;
    border-bottom:1px solid transparent;
    background:var(--surface-muted);
    transition:background .25s var(--ease),border-color .25s var(--ease);
}
.panel-doc-section > summary::-webkit-details-marker{display:none}
.panel-doc-section > summary::marker{content:""}
.panel-doc-section > summary:hover,
.panel-doc-section > summary:focus-visible{background:var(--bg-soft)}
.panel-doc-section[open] > summary{border-bottom-color:var(--border-soft)}
.panel-doc-summary-inner{
    display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.panel-doc-chevron{
    flex-shrink:0;width:28px;height:28px;border-radius:50%;
    background:var(--surface);border:1px solid var(--border);
    position:relative;transition:transform .25s var(--ease);
}
.panel-doc-chevron::before{
    content:"";
    position:absolute;top:50%;left:50%;
    width:7px;height:7px;margin:-4px 0 0 -5px;
    border-right:2px solid var(--text-secondary);
    border-bottom:2px solid var(--text-secondary);
    transform:rotate(45deg);
}
.panel-doc-section[open] .panel-doc-chevron{transform:rotate(180deg)}
.panel-doc-section .card-body{border-top:none}
.badge-nuevo{
    display:inline-flex;align-items:center;margin-left:8px;padding:2px 7px;border-radius:6px;
    background:var(--apple-blue-soft);color:var(--apple-blue);font-size:9px;font-weight:700;
    letter-spacing:.08em;text-transform:uppercase;vertical-align:middle;
}
.badge-nuevo-inline{margin-left:4px;padding:2px 6px;font-size:8px}
.grid-main .card{margin-bottom:24px}
.grid-main .panel-doc-section{margin-bottom:24px}
.grid-main .card:last-child,
.grid-main .panel-doc-section:last-child{margin-bottom:0}

.portal-cobros-section{border-color:rgba(180,35,24,0.18);box-shadow:0 0 0 1px rgba(180,35,24,0.06)}
.portal-cobros-section > summary{background:linear-gradient(180deg,rgba(255,59,48,0.06) 0%,transparent 100%)}
.portal-cobros-section[open] > summary{border-bottom-color:rgba(180,35,24,0.12)}
.portal-cobros-section .panel-doc-summary-inner{align-items:center;gap:14px}
.portal-cobros-alert{
    flex:0 0 auto;width:28px;height:28px;border-radius:50%;
    display:inline-flex;align-items:center;justify-content:center;
    background:#ff3b30;color:#fff;font-size:16px;font-weight:800;line-height:1;
    box-shadow:0 2px 8px rgba(255,59,48,0.35);
}
.portal-cobros-body{padding-top:18px}
.portal-cobro-item{padding:0}
.portal-cobro-item-sep{margin-top:20px;padding-top:20px;border-top:1px solid var(--border-soft)}
.portal-cobro-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:10px}
.portal-cobro-periodo{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--text)}
.portal-cobro-meta{margin:0;font-size:13px;color:var(--text-secondary);line-height:1.45}
.portal-cobro-total{margin:0;font-size:22px;font-weight:700;color:#ff3b30;font-variant-numeric:tabular-nums;white-space:nowrap}
.portal-cobro-importes{display:flex;flex-wrap:wrap;gap:8px 16px;margin-bottom:14px;font-size:13px;color:var(--text-secondary);font-variant-numeric:tabular-nums}
.portal-cobro-transfer{
    background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:12px;
    padding:16px 18px;margin-bottom:12px;
}
.portal-cobro-transfer-title{margin:0 0 12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary)}
.portal-cobro-dl{margin:0;display:grid;gap:10px}
.portal-cobro-dl div{display:grid;gap:2px}
.portal-cobro-dl dt{margin:0;font-size:12px;color:var(--text-secondary)}
.portal-cobro-dl dd{margin:0;font-size:14px;font-weight:600;color:var(--text);word-break:break-word}
.portal-cobro-dl .portal-cobro-mono{font-family:ui-monospace,'SF Mono',Consolas,monospace;font-size:13px;letter-spacing:.03em}
.portal-cobro-dl-total{padding-top:10px;margin-top:2px;border-top:1px dashed var(--border-soft)}
.portal-cobro-dl-total dd{font-size:24px;color:var(--accent,#0071e3)}
.portal-cobro-hint{margin:0;font-size:12px;color:var(--text-tertiary);line-height:1.55}
.portal-cobro-hint a{color:var(--accent,#0071e3);text-decoration:none;font-weight:600}
.portal-cobro-hint a:hover{text-decoration:underline}

.client-account-card{max-width:560px}
.client-account-submit{width:auto;min-width:220px;padding:13px 28px;margin-top:8px}
.client-back-link{margin-top:20px;font-size:13px}
.client-back-link a{color:var(--text);text-decoration:none;font-weight:600;border-bottom:1px solid var(--gold-muted)}
.client-back-link a:hover{color:var(--gold)}

/* Visor ver.php — PDF a pantalla completa */
body.viewer-body{
    margin:0;background:#525659;overflow:hidden;
}
.viewer-topbar{
    position:fixed;top:0;left:0;right:0;z-index:20;height:52px;
    background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);
    border-bottom:1px solid var(--border);padding:0 20px;
    display:flex;align-items:center;gap:12px;
}
.viewer-topbar .btn-volver{
    display:inline-flex;align-items:center;gap:8px;padding:8px 14px;
    background:var(--accent);color:#fff;text-decoration:none;border-radius:8px;
    font-size:13px;font-weight:600;white-space:nowrap;flex-shrink:0;
}
.viewer-topbar .btn-volver:hover{background:#2a2a28}
.viewer-topbar-info{
    flex:1;min-width:0;display:flex;align-items:center;gap:10px;overflow:hidden;
}
.viewer-topbar-tipo{
    font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;
    color:var(--gold);flex-shrink:0;
}
.viewer-topbar-nombre{
    font-size:13px;font-weight:600;color:var(--text);
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.viewer-topbar .btn-descargar{
    padding:8px 14px;border:1px solid var(--border);border-radius:8px;
    color:var(--text-secondary);text-decoration:none;font-size:12px;font-weight:600;
    white-space:nowrap;flex-shrink:0;background:var(--surface);
}
.viewer-topbar .btn-descargar:hover{border-color:#ccc7bf;color:var(--text)}
.viewer-pdf{
    position:fixed;top:52px;left:0;width:100%;
    height:calc(100vh - 52px);height:calc(100dvh - 52px);
    border:none;display:block;background:#525659;
}
.viewer-image-wrap{
    position:fixed;top:52px;left:0;right:0;bottom:0;
    overflow:auto;background:var(--bg);padding:24px;text-align:center;
}
.viewer-image-wrap img{
    max-width:100%;height:auto;border-radius:var(--radius);
    box-shadow:var(--shadow-sm);background:#fff;
}
.viewer-fallback{
    position:fixed;top:52px;left:0;right:0;bottom:0;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    padding:24px;text-align:center;color:var(--text-secondary);font-size:15px;
    background:var(--bg);
}
.viewer-fallback a{
    display:inline-block;margin-top:20px;padding:12px 24px;background:var(--accent);
    color:#fff;text-decoration:none;border-radius:8px;font-weight:600;font-size:14px;
}

/* Legacy aliases */
.topbar{display:flex;align-items:center;gap:12px;padding:14px 24px;background:rgba(255,255,255,0.92);border-bottom:1px solid var(--border)}
.topbar-info{flex:1;min-width:0}
.topbar-tipo{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--gold)}
.topbar-nombre{font-size:14px;font-weight:600;word-break:break-word}
.btn-volver{
    display:inline-flex;align-items:center;gap:8px;padding:9px 16px;
    background:var(--accent);color:#fff;text-decoration:none;border-radius:8px;
    font-size:13px;font-weight:600;white-space:nowrap;flex-shrink:0;
}
.btn-panel,.btn-descargar{
    padding:8px 14px;border:1px solid var(--border);border-radius:8px;
    color:var(--text-secondary);text-decoration:none;font-size:12px;font-weight:600;
    white-space:nowrap;background:var(--surface);
}
.viewer{flex:1;display:flex;flex-direction:column;min-height:0}
.viewer-inner{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin:16px;min-height:480px}
.viewer iframe{width:100%;height:100%;min-height:480px;border:none}
.viewer img{max-width:100%;height:auto;display:block;margin:0 auto;padding:32px}

/* Firma firmar.php */
body.firma-body{-webkit-tap-highlight-color:transparent;background:var(--bg)}
.topbar-firma{
    background:rgba(255,255,255,0.92);backdrop-filter:blur(12px);
    border-bottom:1px solid var(--border);padding:14px 28px;
    display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;
}
.topbar-firma img{width:auto;height:32px;border-radius:8px}
.btn-back{
    display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;
    color:var(--text-secondary);text-decoration:none;padding:8px 14px;border-radius:8px;
    border:1px solid var(--border);background:var(--surface);transition:all .2s;
}
.btn-back:hover{background:var(--surface-muted);color:var(--text)}
.page{max-width:720px;margin:0 auto;padding:40px 24px 80px;animation:fadeUp .6s var(--ease) both}
.page-title{font-family:var(--font-display);font-size:32px;font-weight:400;letter-spacing:-0.02em;margin-bottom:8px}
.page-sub{font-size:15px;color:var(--text-secondary);margin-bottom:28px}
.doc-info{
    background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
    padding:20px 22px;display:flex;align-items:center;gap:16px;margin-bottom:20px;box-shadow:var(--shadow-xs);
}
.doc-nombre{font-size:15px;font-weight:600;margin-bottom:4px;word-break:break-word}
.doc-meta{font-size:13px;color:var(--text-tertiary)}
.btn-ver-doc{
    margin-left:auto;padding:8px 14px;border:1px solid var(--border);border-radius:8px;
    background:var(--surface);font-family:inherit;font-size:12px;font-weight:600;
    color:var(--text-secondary);text-decoration:none;white-space:nowrap;transition:all .2s;
}
.btn-ver-doc:hover{background:var(--surface-muted);color:var(--text)}
.doc-preview{
    background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
    overflow:hidden;margin-bottom:20px;box-shadow:var(--shadow-xs);
}
.doc-preview iframe{width:100%;height:480px;border:none;display:block}
.firma-section{
    background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
    overflow:hidden;margin-bottom:20px;box-shadow:var(--shadow-xs);
}
.firma-head{padding:20px 22px 16px;border-bottom:1px solid var(--border-soft);background:var(--surface-muted)}
.firma-head h2{font-size:16px;font-weight:600;margin-bottom:4px}
.firma-head p{font-size:14px;color:var(--text-secondary)}
.firma-canvas-wrap{padding:22px}
.firma-label{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:10px}
#canvas-firma{
    width:100%;height:180px;border:1px dashed var(--border);border-radius:10px;
    background:var(--surface-muted);cursor:crosshair;display:block;touch-action:none;
}
#canvas-firma.tiene-firma{border-color:var(--gold);border-style:solid;background:#fff}
.firma-actions{display:flex;justify-content:flex-end;margin-top:10px}
.btn-limpiar{
    font-size:12px;color:var(--text-secondary);background:var(--surface-muted);border:1px solid var(--border);
    cursor:pointer;padding:7px 12px;border-radius:8px;font-family:inherit;font-weight:600;
}
.aviso{
    background:var(--surface-muted);border-radius:10px;padding:16px 18px;
    font-size:13px;color:var(--text-secondary);line-height:1.6;margin:0 22px 22px;border:1px solid var(--border-soft);
}
.page .btn-firmar{
    display:block;width:calc(100% - 44px);margin:0 22px 24px;padding:16px 24px;
    background:var(--apple-blue);color:#fff;border:none;border-radius:var(--radius-pill);
    font-family:inherit;font-size:17px;font-weight:400;letter-spacing:-0.022em;cursor:pointer;
    transition:background .2s var(--ease),transform .15s;
}
.page .btn-firmar:hover:not(:disabled){background:var(--apple-blue-hover);transform:scale(1.01)}
.page .btn-firmar:disabled{background:#d2d2d7;color:#86868b;cursor:not-allowed;transform:none}
.firmado-ok{text-align:center;padding:56px 24px}
.ok-icono{
    width:72px;height:72px;background:var(--success-soft);border-radius:50%;
    display:flex;align-items:center;justify-content:center;font-size:32px;margin:0 auto 24px;color:var(--success);
}
.ok-titulo{font-family:var(--font-display);font-size:32px;font-weight:400;letter-spacing:-0.02em;margin-bottom:12px}
.ok-sub{font-size:15px;color:var(--text-secondary);line-height:1.6;margin-bottom:28px;max-width:480px;margin-left:auto;margin-right:auto}
.ok-info{
    background:var(--surface-muted);border:1px solid var(--border-soft);border-radius:10px;
    padding:18px 22px;font-size:13px;color:var(--text-secondary);margin-bottom:24px;
    text-align:left;line-height:1.8;max-width:420px;margin-left:auto;margin-right:auto;
}
.btn-ver-firmado{
    display:inline-block;padding:12px 28px;background:var(--apple-blue);color:#fff;
    border-radius:var(--radius-pill);text-decoration:none;font-size:17px;font-weight:400;
    letter-spacing:-0.022em;margin-bottom:12px;transition:background .2s,transform .15s;
}
.btn-ver-firmado:hover{background:var(--apple-blue-hover);transform:scale(1.01)}
.page .btn-volver{display:block;text-align:center;color:var(--text-secondary);text-decoration:none;font-size:13px;margin-top:8px}

/* ── RESPONSIVE ── */
@media(max-width:834px){
    .apple-globalnav-menu,.apple-globalnav-actions{display:none}
    .apple-globalnav-toggle{display:flex}
    .apple-globalnav.open .apple-globalnav-mobile{display:block}
    .apple-globalnav.open{
        background:rgba(251,251,253,0.95);
        backdrop-filter:saturate(180%) blur(20px);
        -webkit-backdrop-filter:saturate(180%) blur(20px);
    }
    .shell,.shell-with-nav{padding-top:calc(var(--nav-h) + 32px)}
    .stats{grid-template-columns:1fr}
    .doc-panel-item{grid-template-columns:40px minmax(0,1fr) !important;grid-template-rows:auto auto}
    .doc-panel-actions{grid-column:1 / -1;justify-content:flex-start}
    .grid{grid-template-columns:1fr}
    .hero-title{font-size:32px}
    .hero-desc{font-size:17px}
    .client-item{grid-template-columns:40px 1fr auto;grid-template-rows:auto auto}
    .client-cat-form,.client-del-form{grid-column:2 / -1}
    .manage-toolbar .search-wrap{max-width:none}
    .menuem-savebar{
        left:0;right:0;bottom:0;width:100%;transform:none;
        border-radius:0;border-left:none;border-right:none;border-bottom:none;
    }
}

@media(max-width:960px){
    .shell{padding:calc(var(--nav-h) + 28px) 20px 48px}
}

@media(max-width:640px){
    .menuem-savebar{flex-direction:column;align-items:stretch;text-align:center}
    .menuem-savebar .btn-primary{width:100%}
}

@media(max-width:600px){
    .shell{padding:24px 16px 48px}
    .card-body{padding:18px}
    .login-card{padding:32px 24px}
    .logo-area img,.login-logo,.breso-logo-login{height:64px;max-width:150px}
    .breso-logo-nav,.apple-globalnav-brand img{height:30px;max-width:84px}
    .logo-area h1,.login-title{font-size:24px}
    .viewer-topbar{padding:0 12px;height:48px}
    .viewer-pdf{top:48px;height:calc(100vh - 48px);height:calc(100dvh - 48px)}
    .viewer-image-wrap,.viewer-fallback{top:48px}
    .picker-filters{width:100%}
}

@media(prefers-reduced-motion:reduce){
    *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
