/* ═══════════════════════════════════════════════════════════════
   INVITAME DIGITAL — Dashboard CSS (Login + Portal de Clientes)
═══════════════════════════════════════════════════════════════ */

/* ─── VARS ──────────────────────────────────────────────────── */
:root{--cream:#FAF8F4;--cream-d:#F2EDE5;--charcoal:#1C1C1E;--gold:#C4A97D;--gold-d:#9E7D52;--white:#FFFFFF;--border:#E8E2D8;--muted:#888;--green:#2e7d32;--red:#c62828;--orange:#f57c00;--blue:#3A4E66;--font-d:'Cormorant Garamond',serif;--font-b:'Jost',sans-serif;--shadow-sm:0 2px 8px rgba(0,0,0,.06);--shadow-md:0 8px 24px rgba(0,0,0,.10);--shadow-lg:0 20px 60px rgba(0,0,0,.14);--radius:12px;--nav-h:60px;}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{font-family:var(--font-b);background:var(--cream);color:var(--charcoal);-webkit-font-smoothing:antialiased;overflow-x:hidden;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}

/* ═══════════════════════════════════════════════════════════════
   LOGIN PAGE
═══════════════════════════════════════════════════════════════ */
.login-wrap{display:grid;grid-template-columns:1fr 1fr;min-height:100vh;}

/* Panel decorativo izquierdo */
.login-deco{background:var(--charcoal);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:48px;}
.deco-content{position:relative;z-index:2;color:#fff;}
.deco-logo{font-family:var(--font-d);font-size:2.2rem;font-weight:400;color:var(--gold);margin-bottom:12px;}
.deco-tagline{font-size:.9rem;color:rgba(255,255,255,.6);line-height:1.6;margin-bottom:40px;max-width:300px;}
.deco-features{display:flex;flex-direction:column;gap:14px;}
.deco-feat{display:flex;align-items:center;gap:12px;font-size:.85rem;color:rgba(255,255,255,.7);}
.deco-feat i{width:20px;color:var(--gold);font-size:.8rem;}
.deco-circles{position:absolute;inset:0;pointer-events:none;}
.deco-c{position:absolute;border-radius:50%;opacity:.06;}
.c1{width:500px;height:500px;background:var(--gold);top:-150px;right:-150px;}
.c2{width:300px;height:300px;background:var(--gold);bottom:-100px;left:-50px;}
.c3{width:200px;height:200px;background:#fff;top:50%;left:30%;}

/* Panel formulario derecho */
.login-form-panel{display:flex;align-items:center;justify-content:center;padding:48px 40px;background:var(--white);}
.login-form-inner{width:100%;max-width:400px;}
.back-link{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;color:var(--muted);margin-bottom:36px;transition:.2s;}
.back-link:hover{color:var(--charcoal);}
.login-header{text-align:center;margin-bottom:32px;}
.login-icon{font-size:2.5rem;color:var(--gold);margin-bottom:12px;}
.login-header h1{font-family:var(--font-d);font-size:2rem;font-weight:400;color:var(--charcoal);margin-bottom:8px;}
.login-header p{font-size:.9rem;color:var(--muted);}
.login-alert{padding:11px 16px;border-radius:8px;font-size:.85rem;margin-bottom:20px;display:flex;align-items:center;gap:8px;}
.alert-error{background:#ffebee;color:var(--red);border:1px solid #ffcdd2;}
.alert-info{background:#e3f2fd;color:#1565c0;border:1px solid #bbdefb;}
.login-form{display:flex;flex-direction:column;gap:16px;}
.form-field label{display:flex;align-items:center;gap:6px;font-size:.75rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;}
.form-field input{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:8px;font-family:var(--font-b);font-size:.9rem;color:var(--charcoal);background:#fafafa;transition:border-color .2s;}
.form-field input:focus{outline:none;border-color:var(--charcoal);background:#fff;}
.pass-wrap{position:relative;}
.pass-wrap input{padding-right:44px;}
.pass-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--muted);cursor:pointer;font-size:.9rem;padding:4px;}
.btn-login{width:100%;padding:14px;background:var(--charcoal);color:#fff;border:none;border-radius:8px;font-family:var(--font-b);font-size:.9rem;font-weight:500;cursor:pointer;transition:.25s;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:4px;}
.btn-login:hover{background:#333;}
.login-footer-links{text-align:center;margin-top:24px;font-size:.8rem;color:var(--muted);display:flex;flex-direction:column;gap:8px;}
.login-footer-links a{color:var(--gold-d);transition:.2s;}
.login-footer-links a:hover{color:var(--charcoal);}
.hidden{display:none!important;}

/* ═══════════════════════════════════════════════════════════════
   PORTAL — LAYOUT
═══════════════════════════════════════════════════════════════ */
.portal-body{background:var(--cream);min-height:100vh;}

/* Topbar */
.portal-topbar{position:fixed;top:0;left:0;right:0;height:var(--nav-h);background:var(--white);border-bottom:1px solid var(--border);z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 24px;box-shadow:var(--shadow-sm);}
.portal-brand{font-family:var(--font-d);font-size:1.3rem;font-weight:400;color:var(--charcoal);}
.portal-user-info{display:flex;align-items:center;gap:10px;}
.portal-avatar{width:36px;height:36px;background:var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:.85rem;}
.portal-user-name{font-weight:600;font-size:.85rem;color:var(--charcoal);}
.portal-user-role{font-size:.7rem;color:var(--muted);}
.portal-logout-btn{width:36px;height:36px;border:1.5px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.85rem;transition:.2s;margin-left:6px;}
.portal-logout-btn:hover{border-color:var(--red);color:var(--red);}

/* Sidebar + main */
.portal-layout{display:grid;grid-template-columns:220px 1fr;margin-top:var(--nav-h);min-height:calc(100vh - var(--nav-h));}
.portal-sidebar{background:var(--white);border-right:1px solid var(--border);padding:24px 12px;display:flex;flex-direction:column;justify-content:space-between;position:sticky;top:var(--nav-h);height:calc(100vh - var(--nav-h));overflow-y:auto;}
.portal-nav{display:flex;flex-direction:column;gap:4px;}
.portal-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;font-size:.83rem;font-weight:500;color:var(--muted);transition:.2s;cursor:pointer;}
.portal-nav-item:hover{background:var(--cream);color:var(--charcoal);}
.portal-nav-item.active{background:var(--charcoal);color:#fff;}
.portal-nav-item i{width:16px;text-align:center;}
.portal-sidebar-footer{padding-top:12px;border-top:1px solid var(--border);}
.portal-main{padding:28px;overflow-y:auto;}

/* Sections */
.portal-section{display:block;}
.portal-section-header{margin-bottom:24px;}
.portal-section-header h2{font-family:var(--font-d);font-size:1.8rem;font-weight:400;color:var(--charcoal);margin-bottom:6px;display:flex;align-items:center;gap:10px;}
.portal-section-header p{font-size:.85rem;color:var(--muted);}

/* Stats row */
.portal-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px;}
.p-stat-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:18px;text-align:center;box-shadow:var(--shadow-sm);}
.p-stat-num{font-size:2rem;font-weight:700;line-height:1;margin-bottom:5px;}
.p-stat-lbl{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;}
.blue{color:var(--blue);}.green{color:var(--green);}.red{color:var(--red);}.orange{color:var(--orange);}

/* Invitation grid */
.portal-inv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;}
.portal-inv-card{background:var(--white);border:1px solid var(--border);border-radius:16px;overflow:hidden;transition:box-shadow .25s,transform .25s;}
.portal-inv-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);}
.portal-inv-thumb{height:160px;position:relative;overflow:hidden;}
.portal-inv-thumb img{width:100%;height:100%;object-fit:cover;}
.thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem;}
.inv-tipo-badge{position:absolute;bottom:10px;left:10px;background:rgba(255,255,255,.92);padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:600;color:var(--charcoal);}
.portal-inv-body{padding:18px;}
.inv-title{font-family:var(--font-d);font-size:1.3rem;font-weight:500;color:var(--charcoal);margin-bottom:4px;}
.inv-date{font-size:.78rem;color:var(--muted);margin-bottom:14px;display:flex;align-items:center;gap:6px;}
.inv-mini-stats{display:flex;gap:8px;margin-bottom:14px;}
.mini-stat{flex:1;background:var(--cream);border-radius:8px;padding:8px 6px;text-align:center;}
.mini-stat strong{font-size:1.3rem;font-weight:700;display:block;line-height:1;}
.mini-stat span{font-size:.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;}
.mini-stat.green strong{color:var(--green);}
.mini-stat.red strong{color:var(--red);}
.mini-stat.orange strong{color:var(--orange);}
.inv-progress-wrap{margin-bottom:14px;}
.inv-progress{height:6px;background:var(--border);border-radius:3px;overflow:hidden;}
.inv-progress-fill{height:100%;border-radius:3px;transition:width .5s;}
.inv-actions{display:flex;gap:6px;flex-wrap:wrap;}
.inv-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 12px;border-radius:50px;font-family:var(--font-b);font-size:.75rem;font-weight:500;cursor:pointer;transition:.2s;white-space:nowrap;border:none;}
.inv-btn-primary{background:var(--charcoal);color:#fff;}
.inv-btn-primary:hover{background:#333;color:#fff;}
.inv-btn-outline{background:transparent;color:var(--charcoal);border:1.5px solid var(--border);}
.inv-btn-outline:hover{border-color:var(--charcoal);}
.inv-btn-ghost{background:var(--cream);color:var(--muted);border:1px solid var(--border);}
.inv-btn-ghost:hover{color:var(--charcoal);}
.inv-btn-sm{padding:5px 10px;font-size:.7rem;}

/* Empty state */
.portal-empty{text-align:center;padding:60px 24px;color:var(--muted);}
.empty-icon{font-size:3rem;display:block;margin-bottom:16px;}
.portal-empty h3{font-family:var(--font-d);font-size:1.6rem;color:var(--charcoal);margin-bottom:10px;}
.portal-empty p{font-size:.9rem;margin-bottom:20px;}

/* Stats cards */
.stats-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:16px;box-shadow:var(--shadow-sm);}
.stats-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--border);}
.stats-card-title{font-family:var(--font-d);font-size:1.3rem;font-weight:500;color:var(--charcoal);}
.stats-bars{display:flex;flex-direction:column;gap:12px;margin-bottom:20px;}
.stats-bar-row{display:grid;grid-template-columns:110px 1fr 80px;align-items:center;gap:12px;}
.stats-bar-label{font-size:.8rem;font-weight:500;color:var(--charcoal);}
.stats-bar-track{height:8px;background:var(--border);border-radius:4px;overflow:hidden;}
.stats-bar-fill{height:100%;border-radius:4px;transition:width .7s ease;}
.stats-bar-fill.green{background:var(--green);}
.stats-bar-fill.red{background:var(--red);}
.stats-bar-fill.orange{background:var(--orange);}
.stats-bar-count{font-weight:700;font-size:.85rem;}
.stats-bar-count span{font-weight:400;font-size:.75rem;color:var(--muted);}
.stats-totals{display:flex;gap:24px;padding-top:14px;border-top:1px solid var(--border);}
.stats-total-item{text-align:center;}
.stats-total-num{font-size:1.8rem;font-weight:700;line-height:1;color:var(--charcoal);}
.stats-total-num.green{color:var(--green);}
.stats-total-lbl{font-size:.7rem;color:var(--muted);margin-top:4px;}

/* RSVP Table */
.rsvp-selector{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:16px;}
.rsvp-selector label{font-size:.75rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:10px;}
.rsvp-select-btns{display:flex;gap:8px;flex-wrap:wrap;}
.rsvp-sel-btn{padding:7px 14px;background:var(--cream);border:1.5px solid var(--border);border-radius:50px;font-family:var(--font-b);font-size:.78rem;cursor:pointer;transition:.2s;color:var(--charcoal);}
.rsvp-sel-btn:hover,.rsvp-sel-btn.active{background:var(--charcoal);border-color:var(--charcoal);color:#fff;}
.rsvp-table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;}
.rsvp-table-title{font-family:var(--font-d);font-size:1.2rem;font-weight:500;}
.rsvp-table-wrap{overflow-x:auto;}
.rsvp-table{width:100%;border-collapse:collapse;background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);}
.rsvp-table th{background:var(--charcoal);color:#fff;padding:10px 14px;text-align:left;font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;font-weight:600;}
.rsvp-table td{padding:10px 14px;border-bottom:1px solid #f5f5f5;font-size:.85rem;vertical-align:middle;}
.rsvp-table tr:last-child td{border-bottom:none;}
.rsvp-table tr:hover td{background:#fafafa;}
.badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:.72rem;font-weight:600;}
.badge-ok{background:#e8f5e9;color:var(--green);}
.badge-no{background:#ffebee;color:var(--red);}
.badge-pend{background:#fff8e1;color:var(--orange);}

/* Responsive */
@media(max-width:900px){
    .login-wrap{grid-template-columns:1fr;}.login-deco{display:none;}
    .portal-layout{grid-template-columns:1fr;}.portal-sidebar{position:static;height:auto;border-right:none;border-bottom:1px solid var(--border);padding:12px;flex-direction:row;}.portal-nav{flex-direction:row;flex-wrap:wrap;gap:4px;}.portal-sidebar-footer{display:none;}
    .portal-stats-row{grid-template-columns:1fr 1fr;}
    .stats-bar-row{grid-template-columns:80px 1fr 60px;}
}
@media(max-width:600px){
    .portal-topbar{padding:0 14px;}.portal-main{padding:16px;}
    .portal-stats-row{grid-template-columns:1fr 1fr;gap:10px;}.p-stat-num{font-size:1.5rem;}
    .portal-inv-grid{grid-template-columns:1fr;}
    .inv-actions{gap:4px;}
}

/* ─── LOGIN: estilos extra ─────────────────────────────────────── */
.portal-section { display: none; }
.portal-section:first-child { display: block; }
