/* ================================================================
   PÁGINAS CHORRILLANAS — CSS v6
   Dark mode completo · Espacios compactos · Todo corregido
   ================================================================ */
:root {
  --navy:#1a237e;--navy-m:#283593;--navy-l:#3949ab;--navy-xl:#e8eaf6;
  --gold:#fdd835;--gold-d:#f9a825;--gold-bg:#fffde7;
  --green:#2e7d32;--green-bg:#e8f5e9;
  --red:#c62828;--red-l:#ef5350;--red-bg:#ffebee;
  --bg:#f4f5f7;--white:#fff;
  --brd:#e0e0e0;--brd-d:#bdbdbd;
  --tx:#212121;--tx2:#424242;--txm:#757575;--txl:#9e9e9e;
  --sh0:0 1px 3px rgba(0,0,0,.07);
  --sh1:0 2px 8px rgba(0,0,0,.10);
  --sh2:0 4px 16px rgba(0,0,0,.12);
  --sh3:0 8px 28px rgba(0,0,0,.14);
  --r4:4px;--r6:6px;--r8:8px;--r10:10px;--r12:12px;--r16:16px;
  --tr:.18s ease;
}

/* ── DARK MODE COMPLETO ── */
[data-theme="dark"]{
  --bg:#0d1117;--white:#161b22;
  --brd:#30363d;--brd-d:#484f58;
  --tx:#e6edf3;--tx2:#c9d1d9;--txm:#8b949e;--txl:#6e7681;
  --navy-xl:#0d1f3c;--gold-bg:#1a1400;--green-bg:#0a1f0a;--red-bg:#1f0a0a;
}
[data-theme="dark"] body{background:var(--bg);color:var(--tx);}
/* Cards y superficies */
[data-theme="dark"] .card,
[data-theme="dark"] .biz-card,
[data-theme="dark"] .cat-card,
[data-theme="dark"] .serv-card,
[data-theme="dark"] .tab-panel,
[data-theme="dark"] .aside-card,
[data-theme="dark"] .ms-header,
[data-theme="dark"] .step-card,
[data-theme="dark"] .plan-card,
[data-theme="dark"] .msg-item-wrap,
[data-theme="dark"] .msg-bubble-in,
[data-theme="dark"] .fav-card{background:var(--white);border-color:var(--brd);}
/* Formularios */
[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select,
[data-theme="dark"] .form-check-input{background:var(--white);color:var(--tx);border-color:var(--brd-d);}
/* Panel Admin */
[data-theme="dark"] .sidebar{background:#060d1e;}
[data-theme="dark"] .panel-main{background:var(--bg);}
[data-theme="dark"] .stat-card{background:var(--white);border-color:var(--brd);}
[data-theme="dark"] .tbl{color:var(--tx);}
[data-theme="dark"] .tbl>:not(caption)>*>*{background:transparent;color:var(--tx);border-color:var(--brd);}
[data-theme="dark"] .tbl thead{background:#0d1f3c;}
[data-theme="dark"] .tbl tbody tr:hover{background:rgba(255,255,255,.04);}
/* Navbar del admin con dark mode */
[data-theme="dark"] .breadcrumb-bar{background:var(--white);border-color:var(--brd);}
/* Tabs */
[data-theme="dark"] .ms-tabs{background:var(--white);border-color:var(--brd);}
[data-theme="dark"] .tab-btn{color:var(--txm);}
[data-theme="dark"] .tab-btn.active{color:var(--tx);}
[data-theme="dark"] .tab-btn:hover{color:var(--tx);background:rgba(255,255,255,.05);}
/* Search */
[data-theme="dark"] .search-box,[data-theme="dark"] .nav-search{background:var(--white);}
[data-theme="dark"] .search-box input,[data-theme="dark"] .nav-search input{background:var(--white);color:var(--tx);}
[data-theme="dark"] .search-box select{background:#0d1f3c;color:var(--txm);border-color:var(--brd);}
[data-theme="dark"] .search-suggest{background:var(--white);border-color:var(--brd);}
[data-theme="dark"] .suggest-row{color:var(--tx);}
[data-theme="dark"] .suggest-row:hover{background:var(--navy-xl);}
/* Badges y botones */
[data-theme="dark"] .b-navy{background:#0d1f3c;color:#90caf9;}
[data-theme="dark"] .btn-ghost{background:transparent;color:var(--tx);border-color:var(--brd);}
[data-theme="dark"] .btn-ghost:hover{background:rgba(255,255,255,.06);}
/* Plan cards */
[data-theme="dark"] .plan-card{background:var(--white);border-color:var(--brd);}
/* Review */
[data-theme="dark"] .review-summary{background:var(--navy-xl);}
[data-theme="dark"] .review-form{background:rgba(255,255,255,.04);}
/* Misc */
[data-theme="dark"] .cat-card:hover{color:var(--tx);}
[data-theme="dark"] .biz-card:hover{color:var(--tx);}
[data-theme="dark"] .map-addr-box{background:var(--navy-xl);}
[data-theme="dark"] .oferta-strip{background:#1a1400;border-color:rgba(253,216,53,.3);}
[data-theme="dark"] .notif-panel{background:var(--white);border-color:var(--brd);}
[data-theme="dark"] .notif-item:hover{background:rgba(255,255,255,.04);}
[data-theme="dark"] .notif-item.unread{background:rgba(253,216,53,.06);}
/* Mensajería */
[data-theme="dark"] .msg-sidebar{background:var(--white);border-color:var(--brd);}
[data-theme="dark"] .msg-conv-item:hover{background:rgba(255,255,255,.04);}
[data-theme="dark"] .msg-conv-item.active{background:var(--navy-xl);}
[data-theme="dark"] .msg-bubble-in{background:rgba(255,255,255,.07);}
[data-theme="dark"] .msg-input-area{background:var(--white);border-color:var(--brd);}
[data-theme="dark"] .info-row{border-color:var(--brd);}
[data-theme="dark"] .social-pill{background:rgba(255,255,255,.06);color:var(--txm);border-color:var(--brd);}
[data-theme="dark"] .sim-card{background:var(--white);border-color:var(--brd);color:var(--tx);}
[data-theme="dark"] .fav-grid .fav-card:hover{border-color:var(--gold);}

/* BASE */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Outfit',system-ui,sans-serif;background:var(--bg);color:var(--tx);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4,h5,h6{font-family:'Syne',sans-serif;line-height:1.2;}
a{color:var(--navy-l);text-decoration:none;}a:hover{text-decoration:underline;}
img{max-width:100%;display:block;}
button{font-family:inherit;cursor:pointer;}
input,select,textarea{font-family:inherit;}

/* ── NAVBAR ── */
#mainNav{background:var(--navy);position:sticky;top:0;z-index:1000;box-shadow:0 2px 12px rgba(0,0,0,.25);}
.nav-inner{display:flex;align-items:center;gap:.7rem;padding:.52rem 1rem;max-width:1240px;margin:0 auto;}
.brand{font-family:'Syne',sans-serif;font-weight:900;font-size:1.2rem;color:#fff;letter-spacing:-.5px;text-decoration:none;white-space:nowrap;flex-shrink:0;}
.brand em{color:var(--gold);font-style:normal;}
.brand:hover{text-decoration:none;}
.nav-search{flex:1;max-width:380px;display:flex;background:#fff;border-radius:var(--r6);overflow:hidden;box-shadow:0 2px 6px rgba(0,0,0,.18);}
.nav-search input{flex:1;border:none;outline:none;padding:.4rem .85rem;font-size:.84rem;color:var(--tx);}
.nav-search button{background:var(--gold);border:none;padding:.4rem 1rem;font-weight:800;font-size:.84rem;color:var(--navy);}
.nav-search button:hover{background:var(--gold-d);}
.nav-links{display:flex;align-items:center;gap:.3rem;margin-left:auto;flex-shrink:0;}
.nav-a{color:rgba(255,255,255,.8);font-size:.82rem;font-weight:500;padding:.3rem .58rem;border-radius:var(--r4);transition:all var(--tr);text-decoration:none;white-space:nowrap;}
.nav-a:hover{color:var(--gold);background:rgba(255,255,255,.1);text-decoration:none;}
.nav-cta{background:var(--gold);color:var(--navy);font-weight:800;font-size:.8rem;padding:.33rem .9rem;border-radius:20px;text-decoration:none;white-space:nowrap;border:none;}
.nav-cta:hover{background:var(--gold-d);color:var(--navy);text-decoration:none;}
.dark-btn,.notif-btn{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.85);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.88rem;cursor:pointer;text-decoration:none;transition:background var(--tr);}
.dark-btn:hover,.notif-btn:hover{background:rgba(255,255,255,.22);}
.notif-btn{position:relative;}
.notif-badge{position:absolute;top:-3px;right:-3px;background:var(--red-l);color:#fff;font-size:.58rem;font-weight:800;min-width:15px;height:15px;border-radius:50%;display:flex;align-items:center;justify-content:center;}

/* Breadcrumb */
.breadcrumb-bar{background:var(--white);border-bottom:1px solid var(--brd);padding:.45rem 0;font-size:.78rem;color:var(--txm);}
.breadcrumb-bar a{color:var(--navy-l);}
.breadcrumb-bar span{color:var(--navy);font-weight:600;}

/* ── BOTONES ── */
.btn{display:inline-flex;align-items:center;gap:.4rem;border:none;border-radius:var(--r6);font-weight:700;font-size:.88rem;cursor:pointer;transition:all var(--tr);text-decoration:none;white-space:nowrap;padding:.52rem 1.2rem;}
.btn:hover{text-decoration:none;}
.btn-gold {background:var(--gold);color:var(--navy);}   .btn-gold:hover {background:var(--gold-d);color:var(--navy);}
.btn-navy {background:var(--navy);color:#fff;}           .btn-navy:hover {background:var(--navy-m);color:#fff;}
.btn-green{background:var(--green);color:#fff;}          .btn-green:hover{background:#1b5e20;color:#fff;}
.btn-red  {background:var(--red-l);color:#fff;}          .btn-red:hover  {background:var(--red);color:#fff;}
.btn-ghost{background:var(--white);color:var(--navy);border:1.5px solid var(--brd);} .btn-ghost:hover{border-color:var(--navy);background:var(--navy-xl);}
.btn-wa   {background:#25d366;color:#fff;}               .btn-wa:hover   {background:#1da851;color:#fff;}
.btn-lg{padding:.68rem 1.8rem;font-size:.95rem;}
.btn-xl{padding:.82rem 2.2rem;font-size:1.05rem;}
.btn-sm{padding:.32rem .75rem;font-size:.78rem;}
.btn-full{width:100%;justify-content:center;}

/* Card */
.card{background:var(--white);border-radius:var(--r12);border:1px solid var(--brd);box-shadow:var(--sh0);}
.card-head{background:var(--navy);color:#fff;padding:.65rem 1rem;border-radius:var(--r12) var(--r12) 0 0;font-family:'Syne',sans-serif;font-size:.9rem;font-weight:700;display:flex;justify-content:space-between;align-items:center;}
.card-head.gold{background:var(--gold);color:var(--navy);}
.card-head.green{background:var(--green);color:#fff;}
.card-body{padding:.9rem;}

/* Badges */
.badge{font-size:.63rem;font-weight:700;padding:.16rem .52rem;border-radius:20px;display:inline-flex;align-items:center;gap:.2rem;line-height:1.4;}
.b-navy {background:var(--navy-xl);color:var(--navy-l);}
.b-gold {background:var(--gold-bg);color:#8a6c00;}
.b-green{background:var(--green-bg);color:var(--green);}
.b-red  {background:var(--red-bg);color:var(--red);}
.b-hot  {background:#fff3e0;color:#e65100;}
.b-new  {background:#e3f2fd;color:#1565c0;}
.b-white{background:rgba(255,255,255,.22);color:#fff;}

/* ── HERO — COMPACTO ── */
.hero{background:var(--navy);}
.hero-topbar{background:var(--gold);padding:.38rem 1rem;text-align:center;font-size:.78rem;font-weight:800;color:var(--navy);}
.hero-body{padding:2.5rem 0 2rem;background:linear-gradient(135deg,#1a237e 0%,#283593 65%,#1a237e 100%);}
.hero h1{color:#fff;font-size:clamp(1.6rem,4vw,2.8rem);line-height:1.1;letter-spacing:-.5px;}
.hero h1 em{color:var(--gold);font-style:normal;}
.hero-sub{color:rgba(255,255,255,.72);max-width:480px;margin:.7rem 0 1.5rem;font-size:.95rem;}
.free-pill{display:inline-flex;align-items:center;gap:.4rem;background:var(--green);color:#fff;padding:.28rem .9rem;border-radius:20px;font-size:.77rem;font-weight:800;margin-bottom:.8rem;}
.search-wrap{position:relative;max-width:580px;}
.search-box{background:#fff;border-radius:var(--r8);display:flex;box-shadow:0 4px 20px rgba(0,0,0,.22);}
.search-box select{background:#f5f7ff;border:none;border-right:1px solid var(--brd);outline:none;padding:.68rem .9rem;font-family:'Outfit',sans-serif;font-size:.83rem;color:var(--txm);min-width:135px;border-radius:var(--r8) 0 0 var(--r8);}
.search-box input{flex:1;border:none;outline:none;padding:.68rem 1rem;font-size:.93rem;font-family:'Outfit',sans-serif;color:var(--tx);}
.search-box button{background:var(--gold);color:var(--navy);border:none;padding:0 1.4rem;font-weight:800;font-size:.88rem;border-radius:0 var(--r8) var(--r8) 0;white-space:nowrap;}
.search-box button:hover{background:var(--gold-d);}
.search-suggest{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border-radius:var(--r8);box-shadow:var(--sh3);z-index:300;display:none;border:1px solid var(--brd);overflow:hidden;}
.suggest-row{display:flex;align-items:center;gap:.7rem;padding:.58rem .9rem;border-bottom:1px solid var(--brd);text-decoration:none;color:var(--tx);transition:background var(--tr);font-size:.84rem;}
.suggest-row:last-child{border:none;}
.suggest-row:hover{background:var(--gold-bg);text-decoration:none;}
.hero-stats{display:flex;gap:2rem;margin-top:1.5rem;flex-wrap:wrap;}
.hstat-num{font-family:'Syne',sans-serif;font-size:1.7rem;color:var(--gold);font-weight:800;display:block;}
.hstat-lbl{color:rgba(255,255,255,.5);font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;}

/* Section helpers — COMPACTOS */
.sec-tag{display:inline-block;background:var(--gold);color:var(--navy);padding:.16rem .68rem;border-radius:3px;font-size:.67rem;font-weight:800;letter-spacing:.5px;text-transform:uppercase;margin-bottom:.4rem;}
.sec-tag.navy{background:var(--navy);color:#fff;}
.sec-tag.green{background:var(--green);color:#fff;}
.sec-title{color:var(--navy);letter-spacing:-.3px;}
.sec-sub{color:var(--txm);font-size:.9rem;}
.sec-divider{display:flex;align-items:center;gap:.6rem;margin:.7rem 0 .6rem;}
.sec-divider .lbl{font-size:.82rem;font-weight:800;color:var(--navy);white-space:nowrap;}
.sec-divider .line{flex:1;height:1.5px;background:linear-gradient(to right,var(--gold),transparent);}

/* Category grid — COMPACTO */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.6rem;}
.cat-card{background:var(--white);border:1px solid var(--brd);border-radius:var(--r8);padding:.85rem .7rem;text-align:center;text-decoration:none;color:var(--tx);transition:all var(--tr);display:block;position:relative;overflow:hidden;}
.cat-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--cat-color,var(--gold));transform:scaleX(0);transition:transform var(--tr);}
.cat-card:hover{transform:translateY(-3px);box-shadow:var(--sh2);border-color:var(--cat-color,var(--gold));text-decoration:none;color:var(--tx);}
.cat-card:hover::after{transform:scaleX(1);}
.cat-icon{font-size:1.7rem;display:block;margin-bottom:.4rem;transition:transform .3s cubic-bezier(.34,1.56,.64,1);}
.cat-card:hover .cat-icon{transform:scale(1.2);}
.cat-name{font-size:.77rem;font-weight:700;color:var(--navy);display:block;margin-bottom:.1rem;}
.cat-count{font-size:.66rem;color:var(--txl);}

/* BIZ CARDS — ALTURA FIJA */
.biz-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.85rem;}
.biz-card{background:var(--white);border:1px solid var(--brd);border-radius:var(--r10);overflow:hidden;transition:all var(--tr);box-shadow:var(--sh0);display:flex;flex-direction:column;position:relative;text-decoration:none;color:var(--tx);}
.biz-card:hover{transform:translateY(-3px);box-shadow:var(--sh2);border-color:var(--gold);text-decoration:none;color:var(--tx);}
.biz-img-wrap{width:100%;height:150px;overflow:hidden;background:#f8f8f8;flex-shrink:0;position:relative;}
.biz-img-real{width:100%;height:150px;object-fit:cover;display:block;transition:transform .4s ease;}
.biz-card:hover .biz-img-real{transform:scale(1.05);}
.biz-emoji-box{width:100%;height:150px;display:flex;align-items:center;justify-content:center;font-size:3rem;background:linear-gradient(135deg,var(--cat-c,#e8eaf6),var(--cat-c,#c5cae9)44);}
.biz-badges{position:absolute;top:7px;left:7px;display:flex;flex-direction:column;gap:3px;z-index:2;}
.biz-fav{position:absolute;top:7px;right:7px;background:rgba(255,255,255,.9);border:none;width:27px;height:27px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.82rem;cursor:pointer;box-shadow:var(--sh0);transition:all var(--tr);color:#ccc;z-index:2;}
.biz-fav:hover{transform:scale(1.15);}
.biz-fav.active{color:var(--red-l);}
.biz-body{padding:.7rem .85rem;flex:1;display:flex;flex-direction:column;}
.biz-cat-tag{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px;margin-bottom:.28rem;}
.biz-name{font-family:'Syne',sans-serif;font-size:.93rem;color:var(--navy);margin-bottom:.22rem;line-height:1.3;}
.biz-desc-short{font-size:.78rem;color:var(--txm);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5;flex:1;margin-bottom:.5rem;}
.biz-foot{display:flex;justify-content:space-between;align-items:center;padding-top:.45rem;border-top:1px solid var(--brd);margin-top:auto;}
.biz-stars-sm{color:var(--gold-d);font-size:.78rem;}
.biz-stars-sm span{color:var(--txl);font-size:.7rem;}
.biz-wa-tag{color:#25d366;font-size:.7rem;font-weight:700;}

/* ── MINI-TIENDA ── */
.ms-cover{background:var(--navy);position:relative;height:220px;overflow:hidden;}
.ms-cover img.cover-img{width:100%;height:220px;object-fit:cover;display:block;}
.ms-cover .cover-emoji{width:100%;height:220px;display:flex;align-items:center;justify-content:center;font-size:6rem;}
.ms-cover-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.65),transparent 55%);pointer-events:none;}
.ms-cover-info{position:absolute;bottom:.9rem;left:1rem;right:1rem;z-index:2;}
.swiper-cover{height:220px!important;}
.swiper-cover .swiper-slide{height:220px!important;}
.swiper-cover .swiper-slide img{width:100%;height:220px;object-fit:cover;}
.ms-header{background:var(--white);border-bottom:1px solid var(--brd);}
.ms-header-inner{display:flex;gap:.9rem;align-items:flex-start;padding:.9rem 0;flex-wrap:wrap;}
.ms-logo{width:78px;height:78px;border-radius:var(--r10);background:var(--white);border:3px solid var(--white);box-shadow:var(--sh2);overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:2.6rem;margin-top:-39px;position:relative;z-index:2;}
.ms-logo img{width:100%;height:100%;object-fit:contain;}
.ms-info{flex:1;min-width:180px;}
.ms-badges{display:flex;gap:.3rem;flex-wrap:wrap;margin-bottom:.4rem;}
.ms-phrase{display:inline-block;background:var(--navy);color:var(--gold);font-family:'Syne',sans-serif;font-size:.78rem;font-weight:700;padding:.22rem .75rem;border-radius:20px;margin-bottom:.35rem;}
.ms-name{font-family:'Syne',sans-serif;font-size:clamp(1.1rem,3vw,1.7rem);color:var(--navy);line-height:1.2;margin-bottom:.3rem;}
.ms-stars-row{display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--txm);margin-bottom:.28rem;}
.ms-stars-disp{color:var(--gold-d);letter-spacing:.5px;}
.ms-meta{display:flex;gap:.65rem;flex-wrap:wrap;font-size:.77rem;color:var(--txm);}
.ms-fav-btn{background:var(--bg);border:1.5px solid var(--brd);border-radius:50%;width:42px;height:42px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.05rem;flex-shrink:0;transition:all var(--tr);}
.ms-fav-btn.active{border-color:var(--red-l);background:var(--red-bg);}
.ms-tabs{background:var(--white);border-bottom:2px solid var(--brd);position:sticky;top:52px;z-index:100;box-shadow:0 2px 8px rgba(0,0,0,.05);}
.ms-tabs-scroll{overflow-x:auto;scrollbar-width:none;}
.ms-tabs-scroll::-webkit-scrollbar{display:none;}
.tab-btn{padding:.6rem .9rem;font-size:.82rem;font-weight:700;color:var(--txm);border:none;background:none;cursor:pointer;white-space:nowrap;border-bottom:2.5px solid transparent;margin-bottom:-2px;transition:all var(--tr);}
.tab-btn:hover{color:var(--navy);}
.tab-btn.active{color:var(--navy);border-bottom-color:var(--gold);}
.ms-body{background:var(--bg);padding:1rem 0 2rem;}
.ms-aside{position:sticky;top:98px;}
.aside-card{background:var(--white);border-radius:var(--r12);border:1px solid var(--brd);overflow:hidden;margin-bottom:.7rem;box-shadow:var(--sh0);}
.aside-head{background:var(--navy);color:#fff;padding:.7rem .9rem;}
.aside-head-name{font-weight:800;font-size:.92rem;}
.aside-head-sub{color:rgba(255,255,255,.6);font-size:.73rem;margin-top:.12rem;}
.aside-body{padding:.8rem;}
.contact-btn{display:flex;align-items:center;gap:.6rem;padding:.7rem .85rem;border-radius:var(--r6);font-weight:700;font-size:.86rem;text-decoration:none;border:none;cursor:pointer;width:100%;transition:all var(--tr);margin-bottom:.45rem;}
.contact-btn:last-child{margin-bottom:0;}
.c-wa{background:#25d366;color:#fff;} .c-wa:hover{background:#1da851;color:#fff;text-decoration:none;}
.c-tel{background:var(--navy);color:#fff;} .c-tel:hover{background:var(--navy-m);color:#fff;text-decoration:none;}
.c-web{background:var(--bg);color:var(--navy);border:1px solid var(--brd);} .c-web:hover{background:var(--navy-xl);text-decoration:none;}
.aside-info{font-size:.78rem;color:var(--txm);}
.info-row{display:flex;gap:.5rem;align-items:flex-start;padding:.32rem 0;border-bottom:1px solid var(--brd);}
.info-row:last-child{border:none;}
.info-icon{flex-shrink:0;}
.social-pills{display:flex;gap:.35rem;flex-wrap:wrap;margin-top:.65rem;}
.social-pill{font-size:.72rem;padding:.23rem .58rem;border-radius:20px;background:var(--bg);color:var(--txm);border:1px solid var(--brd);cursor:pointer;text-decoration:none;transition:all var(--tr);}
.social-pill:hover{background:var(--navy-xl);color:var(--navy);border-color:var(--navy);text-decoration:none;}
.stat-pills{display:flex;gap:.4rem;margin-top:.7rem;}
.stat-pill{flex:1;text-align:center;background:var(--bg);border-radius:var(--r6);padding:.42rem .2rem;}
.stat-pill .v{font-family:'Syne',sans-serif;font-size:.95rem;color:var(--navy);font-weight:800;display:block;}
.stat-pill .l{font-size:.63rem;color:var(--txl);}
.big-fav-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;background:var(--bg);border:1.5px solid var(--brd);border-radius:var(--r6);padding:.58rem;font-weight:700;font-size:.83rem;color:var(--txm);cursor:pointer;margin-top:.65rem;transition:all var(--tr);}
.big-fav-btn:hover,.big-fav-btn.active{background:var(--red-bg);border-color:var(--red-l);color:var(--red);}
.plan-mini{background:var(--gold-bg);border:1.5px solid var(--gold);border-radius:var(--r10);padding:.7rem .9rem;text-align:center;margin-bottom:.7rem;}
.plan-mini-name{font-size:.7rem;font-weight:800;color:var(--gold-d);text-transform:uppercase;letter-spacing:.5px;}
.plan-mini-desc{font-size:.77rem;color:var(--tx2);margin-top:.2rem;}
.tab-panel{background:var(--white);border-radius:var(--r10);border:1px solid var(--brd);padding:.9rem;margin-bottom:.85rem;box-shadow:var(--sh0);}
.oferta-strip{background:var(--gold-bg);border:1.5px solid var(--gold);border-radius:var(--r8);padding:.75rem .9rem;margin-bottom:.65rem;display:flex;justify-content:space-between;align-items:center;gap:.7rem;}
.oferta-titulo{font-weight:700;font-size:.88rem;color:#e65100;}
.oferta-precio{font-family:'Syne',sans-serif;font-size:1.15rem;font-weight:900;color:var(--green);}
.oferta-antes{text-decoration:line-through;color:var(--txl);font-size:.78rem;}
.oferta-dias{background:var(--red-l);color:#fff;font-size:.67rem;font-weight:700;padding:.16rem .48rem;border-radius:var(--r4);white-space:nowrap;flex-shrink:0;}
.serv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:.7rem;}
.serv-card{background:var(--white);border:1px solid var(--brd);border-radius:var(--r8);overflow:hidden;transition:all var(--tr);}
.serv-card:hover{border-color:var(--navy);box-shadow:var(--sh1);transform:translateY(-2px);}
.serv-img-box{width:100%;height:120px;overflow:hidden;background:#f8f8f8;display:flex;align-items:center;justify-content:center;}
.serv-img-box img{width:100%;height:120px;object-fit:contain;display:block;}
.serv-emoji-box{width:100%;height:120px;display:flex;align-items:center;justify-content:center;font-size:2.8rem;background:#f0f4f8;}
.serv-body{padding:.65rem .75rem;}
.serv-name{font-family:'Syne',sans-serif;font-size:.86rem;color:var(--navy);margin-bottom:.18rem;line-height:1.3;}
.serv-desc{font-size:.75rem;color:var(--txm);margin-bottom:.38rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.serv-price{font-family:'Syne',sans-serif;font-size:1.05rem;color:var(--navy);font-weight:800;}
.serv-price small{font-size:.77rem;color:var(--txm);font-family:'Outfit',sans-serif;font-weight:400;}
.gal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.45rem;}
.gal-thumb{border-radius:var(--r6);overflow:hidden;cursor:zoom-in;border:2px solid transparent;transition:all var(--tr);background:#f8f8f8;}
.gal-thumb:hover{border-color:var(--gold);transform:scale(1.03);}
.gal-thumb img{width:100%;height:100px;object-fit:cover;display:block;}
.video-wrap{border-radius:var(--r8);overflow:hidden;aspect-ratio:16/9;}
.video-wrap iframe{width:100%;height:100%;border:none;}
.map-wrap{border-radius:var(--r8);overflow:hidden;border:1px solid var(--brd);}
#map-leaflet{height:260px;width:100%;}
.map-addr-box{background:var(--navy-xl);border-radius:var(--r8);padding:.75rem .9rem;display:flex;gap:.7rem;align-items:flex-start;}
.map-addr-text{font-size:.84rem;color:var(--navy);font-weight:600;}
.map-addr-ref{font-size:.77rem;color:var(--txm);margin-top:.12rem;}
.review-summary{background:var(--navy-xl);border-radius:var(--r8);padding:.8rem .9rem;display:flex;gap:.9rem;align-items:center;margin-bottom:.85rem;}
.review-big-score{font-family:'Syne',sans-serif;font-size:2.6rem;font-weight:900;color:var(--navy);line-height:1;text-align:center;}
.review-big-stars{color:var(--gold-d);font-size:.95rem;display:block;margin:.18rem 0;}
.review-big-count{font-size:.7rem;color:var(--txm);}
.review-bars{flex:1;display:flex;flex-direction:column;gap:.2rem;}
.bar-row{display:flex;align-items:center;gap:.45rem;font-size:.7rem;color:var(--txm);}
.bar-track{flex:1;height:6px;background:var(--brd);border-radius:4px;overflow:hidden;}
.bar-fill{height:100%;background:var(--gold);border-radius:4px;width:0;transition:width 1s ease;}
.review-item{padding:.7rem 0;border-bottom:1px solid var(--brd);}
.review-item:last-child{border:none;}
.review-top{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.28rem;flex-wrap:wrap;}
.review-author{font-weight:700;font-size:.85rem;color:var(--navy);}
.review-stars{color:var(--gold-d);font-size:.85rem;}
.review-time{font-size:.7rem;color:var(--txl);}
.review-text{font-size:.83rem;color:var(--tx2);line-height:1.6;}
.review-reply{background:var(--gold-bg);border-left:3px solid var(--gold);padding:.45rem .75rem;margin-top:.45rem;font-size:.79rem;border-radius:0 var(--r4) var(--r4) 0;}
.review-form{background:var(--navy-xl);border-radius:var(--r8);padding:.9rem;margin-top:.7rem;}
.review-form h6{color:var(--navy);font-size:.86rem;margin-bottom:.65rem;}
.star-input{display:flex;flex-direction:row-reverse;gap:.18rem;}
.star-input input[type="radio"]{display:none;}
.star-input label{font-size:1.75rem;cursor:pointer;color:#ddd;transition:color var(--tr),transform .25s cubic-bezier(.34,1.56,.64,1);}
.star-input label:hover,.star-input label:hover~label,.star-input input:checked~label{color:var(--gold-d);}
.star-input label:hover{transform:scale(1.25) rotate(-8deg);}
.sim-grid{display:grid;grid-template-columns:1fr 1fr;gap:.45rem;}
.sim-card{background:var(--white);border:1px solid var(--brd);border-radius:var(--r8);padding:.6rem;display:flex;gap:.55rem;align-items:center;transition:all var(--tr);text-decoration:none;color:var(--tx);}
.sim-card:hover{border-color:var(--navy);background:var(--navy-xl);text-decoration:none;}
.sim-icon{width:38px;height:38px;border-radius:var(--r6);background:var(--navy-xl);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0;overflow:hidden;}
.sim-icon img{width:100%;height:100%;object-fit:contain;}
.sim-name{font-size:.78rem;font-weight:700;color:var(--navy);line-height:1.3;}
.sim-cat{font-size:.68rem;color:var(--txm);}
.qr-card{background:var(--navy);border-radius:var(--r10);padding:.9rem;text-align:center;margin-bottom:.7rem;}
.qr-card h6{color:#fff;font-size:.83rem;font-weight:700;margin-bottom:.65rem;}
.qr-img-wrap{background:#fff;border-radius:var(--r6);padding:7px;display:inline-block;margin-bottom:.55rem;}
.qr-img-wrap img{width:100px;height:100px;display:block;}
.qr-sub{color:rgba(255,255,255,.55);font-size:.7rem;}
.share-row{display:flex;gap:.38rem;margin-top:.65rem;}
.share-btn{flex:1;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:.7rem;font-weight:700;padding:.35rem .28rem;border-radius:var(--r4);cursor:pointer;transition:background var(--tr);text-align:center;text-decoration:none;display:block;}
.share-btn:hover{background:rgba(255,255,255,.22);color:#fff;}
.alert-box{display:flex;gap:.65rem;align-items:flex-start;padding:.68rem .9rem;border-radius:var(--r8);font-size:.84rem;margin-bottom:.85rem;}
.alert-box.gold{background:var(--gold-bg);border-left:4px solid var(--gold);}
.alert-box.green{background:var(--green-bg);border-left:4px solid var(--green);}
.alert-box.navy{background:var(--navy-xl);border-left:4px solid var(--navy);}
.alert-box.red{background:var(--red-bg);border-left:4px solid var(--red-l);}

/* SECTIONS */
.sec-gray{background:var(--bg);}
.sec-white{background:var(--white);}
.sec-dark{background:#0d1433;}
.sec-dark .sec-title{color:#e0e8ff;}
.sec-dark .sec-sub{color:rgba(255,255,255,.45);}
.sec-cta{background:linear-gradient(135deg,var(--navy),var(--navy-m));padding:3.5rem 0;text-align:center;}
.sec-cta h2{color:#fff;margin-bottom:.65rem;}
.sec-cta p{color:rgba(255,255,255,.65);max-width:480px;margin:0 auto 1.8rem;}
.step-card{background:var(--white);border:1px solid var(--brd);border-radius:var(--r10);padding:1.3rem 1.1rem;text-align:center;transition:all var(--tr);height:100%;}
.step-card:hover{transform:translateY(-4px);box-shadow:var(--sh2);border-color:var(--gold);}
.step-num{width:44px;height:44px;background:var(--gold);color:var(--navy);border-radius:50%;font-family:'Syne',sans-serif;font-size:1.3rem;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto .8rem;box-shadow:0 4px 12px rgba(253,216,53,.4);transition:transform .3s cubic-bezier(.34,1.56,.64,1);}
.step-card:hover .step-num{transform:scale(1.1) rotate(-5deg);}
.step-title{font-family:'Syne',sans-serif;color:var(--navy);font-size:.93rem;margin-bottom:.32rem;}
.step-desc{font-size:.8rem;color:var(--txm);}
.plan-card{background:var(--white);border:2px solid var(--brd);border-radius:var(--r12);padding:1.6rem 1.3rem;transition:all var(--tr);text-align:center;height:100%;display:flex;flex-direction:column;}
.plan-card.gratis{border-color:var(--green);}
.plan-card.basico{border-color:var(--navy-l);}
.plan-card.premium{border-color:var(--gold);}
.plan-card:hover{transform:translateY(-5px);box-shadow:var(--sh3);}
.plan-precio{font-family:'Syne',sans-serif;font-size:2.4rem;font-weight:900;line-height:1;}
.plan-periodo{font-size:.78rem;color:var(--txm);}
.plan-features{list-style:none;text-align:left;margin:.9rem 0;flex:1;}
.plan-features li{padding:.35rem 0;border-bottom:1px solid var(--brd);font-size:.83rem;display:flex;align-items:center;gap:.5rem;}
.plan-features li:last-child{border:none;}
.plan-features .si::before{content:'✓';color:var(--green);font-weight:800;width:16px;flex-shrink:0;}
.plan-features .no::before{content:'✗';color:var(--brd-d);width:16px;flex-shrink:0;}
.plan-features .no{color:var(--txl);}
.marquee-strip{background:var(--navy-m);overflow:hidden;padding:.45rem 0;}
.marquee-track{display:flex;gap:2rem;animation:marqScroll 22s linear infinite;white-space:nowrap;}
.marquee-item{color:rgba(255,255,255,.85);font-size:.79rem;font-weight:600;display:inline-flex;align-items:center;gap:.4rem;flex-shrink:0;text-decoration:none;}
.marquee-sep{color:rgba(255,255,255,.25);margin:0 .3rem;}
@keyframes marqScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── PANEL ADMIN/EMPRENDEDOR — DARK MODE COMPLETO ── */
.panel-layout{display:flex;min-height:calc(100vh - 52px);}
.sidebar{width:220px;background:var(--navy);flex-shrink:0;}
.sidebar-brand{display:block;padding:1rem 1.1rem .75rem;color:var(--gold);font-family:'Syne',sans-serif;font-size:.77rem;font-weight:800;letter-spacing:1px;text-transform:uppercase;}
.sidebar-menu{list-style:none;}
.sidebar-menu a{display:flex;align-items:center;gap:.6rem;padding:.58rem 1.1rem;color:rgba(255,255,255,.65);text-decoration:none;font-size:.83rem;font-weight:500;transition:all var(--tr);position:relative;}
.sidebar-menu a::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold);transform:scaleY(0);transition:transform var(--tr);}
.sidebar-menu a:hover,.sidebar-menu a.active{background:rgba(255,255,255,.1);color:#fff;text-decoration:none;}
.sidebar-menu a.active::before{transform:scaleY(1);}
.sidebar-divider{border-color:rgba(255,255,255,.08);margin:.35rem 1.1rem;}
.panel-main{flex:1;padding:1.4rem;overflow-x:hidden;background:var(--bg);}
.badge-count{font-size:.6rem;font-weight:800;padding:.08rem .35rem;border-radius:10px;margin-left:4px;display:inline-block;line-height:1.4;}
.stat-card{background:var(--white);border:1px solid var(--brd);border-radius:var(--r10);padding:1rem 1.2rem;box-shadow:var(--sh0);border-left:4px solid var(--navy);}
.stat-card .v{font-family:'Syne',sans-serif;font-size:1.8rem;color:var(--navy);font-weight:800;}
.stat-card .l{color:var(--txm);font-size:.78rem;}
.stat-card.gold {border-left-color:var(--gold);}   .stat-card.gold .v {color:#8a6c00;}
.stat-card.green{border-left-color:var(--green);}  .stat-card.green .v{color:var(--green);}
.stat-card.red  {border-left-color:var(--red-l);}  .stat-card.red .v  {color:var(--red);}

/* ── MENSAJERÍA ── */
.msg-layout{display:grid;grid-template-columns:260px 1fr;gap:0;height:calc(100vh - 180px);min-height:400px;border:1px solid var(--brd);border-radius:var(--r12);overflow:hidden;background:var(--white);}
.msg-sidebar{border-right:1px solid var(--brd);overflow-y:auto;background:var(--white);}
.msg-sidebar-head{padding:.7rem .9rem;border-bottom:1px solid var(--brd);display:flex;justify-content:space-between;align-items:center;background:var(--navy);color:#fff;}
.msg-sidebar-head span{font-weight:700;font-size:.87rem;}
.msg-conv-item{padding:.65rem .9rem;border-bottom:1px solid var(--brd);cursor:pointer;transition:background var(--tr);}
.msg-conv-item:hover{background:var(--navy-xl);}
.msg-conv-item.active{background:var(--navy-xl);border-left:3px solid var(--gold);}
.msg-conv-name{font-weight:700;font-size:.83rem;color:var(--navy);}
.msg-conv-preview{font-size:.75rem;color:var(--txm);display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;margin-top:.1rem;}
.msg-conv-meta{display:flex;justify-content:space-between;align-items:center;margin-top:.15rem;}
.msg-conv-time{font-size:.68rem;color:var(--txl);}
.msg-conv-badge{background:var(--red-l);color:#fff;font-size:.62rem;font-weight:800;min-width:17px;height:17px;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0 3px;}
.msg-main{display:flex;flex-direction:column;overflow:hidden;}
.msg-main-head{padding:.65rem .9rem;border-bottom:1px solid var(--brd);background:var(--white);display:flex;align-items:center;gap:.7rem;}
.msg-main-head h6{margin:0;color:var(--navy);font-size:.9rem;}
.msg-body{flex:1;overflow-y:auto;padding:.85rem;display:flex;flex-direction:column;gap:.7rem;background:var(--bg);}
.msg-bubble{max-width:75%;padding:.6rem .85rem;border-radius:var(--r8);font-size:.85rem;line-height:1.5;}
.msg-bubble-out{background:var(--navy);color:#fff;align-self:flex-end;border-radius:var(--r8) var(--r8) 2px var(--r8);}
.msg-bubble-in{background:var(--white);color:var(--tx);align-self:flex-start;border:1px solid var(--brd);border-radius:var(--r8) var(--r8) var(--r8) 2px;}
.msg-bubble-meta{font-size:.68rem;opacity:.65;margin-top:.25rem;}
.msg-input-area{padding:.65rem .9rem;border-top:1px solid var(--brd);background:var(--white);display:flex;gap:.5rem;align-items:flex-end;}
.msg-input-area textarea{flex:1;border:1.5px solid var(--brd);border-radius:var(--r8);padding:.5rem .75rem;font-size:.85rem;font-family:'Outfit',sans-serif;resize:none;outline:none;color:var(--tx);background:var(--bg);}
.msg-input-area textarea:focus{border-color:var(--navy);}
.msg-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--txm);flex-direction:column;gap:.5rem;}
.msg-new-btn{background:var(--gold);color:var(--navy);border:none;padding:.32rem .7rem;border-radius:var(--r4);font-size:.75rem;font-weight:800;cursor:pointer;}
.msg-new-btn:hover{background:var(--gold-d);}

/* Favoritos page */
.fav-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.85rem;}
.fav-card{background:var(--white);border:1px solid var(--brd);border-radius:var(--r10);overflow:hidden;transition:all var(--tr);box-shadow:var(--sh0);text-decoration:none;color:var(--tx);display:block;}
.fav-card:hover{transform:translateY(-3px);box-shadow:var(--sh2);border-color:var(--gold);text-decoration:none;}
.fav-card .fav-remove{position:absolute;top:6px;right:6px;background:rgba(255,255,255,.9);border:none;width:26px;height:26px;border-radius:50%;font-size:.78rem;cursor:pointer;z-index:2;display:flex;align-items:center;justify-content:center;color:var(--red-l);}

/* Forms */
label{font-weight:600;font-size:.82rem;color:var(--navy);display:block;margin-bottom:.28rem;}
.form-control,.form-select{width:100%;border:1.5px solid var(--brd);border-radius:var(--r6);padding:.46rem .72rem;font-size:.86rem;font-family:'Outfit',sans-serif;outline:none;color:var(--tx);background:var(--white);transition:border-color var(--tr);}
.form-control:focus,.form-select:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(26,35,126,.1);}
.tbl{font-size:.83rem;width:100%;border-collapse:collapse;}
.tbl thead{background:var(--navy);color:#fff;}
.tbl th,.tbl td{padding:.58rem .88rem;border-bottom:1px solid var(--brd);text-align:left;}
.tbl tbody tr:hover{background:var(--navy-xl);}
.pagination .page-link{color:var(--navy);border-color:var(--brd);}
.pagination .page-item.active .page-link{background:var(--navy);border-color:var(--navy);}
.notif-panel{width:295px;max-height:350px;overflow-y:auto;background:var(--white);border:1px solid var(--brd);border-radius:var(--r10);}
.notif-item{padding:.55rem .88rem;border-bottom:1px solid var(--brd);cursor:pointer;transition:background var(--tr);}
.notif-item:hover{background:var(--navy-xl);}
.notif-item.unread{border-left:3px solid var(--gold);background:var(--gold-bg);}
.notif-item h6{font-size:.79rem;color:var(--navy);margin-bottom:.1rem;}
.notif-item p{font-size:.72rem;color:var(--txm);margin:0;}
.notif-item time{font-size:.67rem;color:var(--txl);}

/* AOS */
[data-aos]{opacity:0;transition:opacity .55s ease,transform .55s ease;}
[data-aos].aos-animate{opacity:1;transform:none!important;}
[data-aos="fade-up"]{transform:translateY(22px);}
[data-aos="fade-right"]{transform:translateX(-22px);}
[data-aos="zoom-in"]{transform:scale(.9);}
.skel{background:linear-gradient(90deg,#eee 25%,#e0e0e0 50%,#eee 75%);background-size:200% 100%;animation:skel 1.3s infinite;border-radius:var(--r4);}
@keyframes skel{0%{background-position:200% 0}100%{background-position:-200% 0}}
[data-theme="dark"] .skel{background:linear-gradient(90deg,#1e293b 25%,#2d3f55 50%,#1e293b 75%);background-size:200%;}
#lightbox-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:9999;align-items:center;justify-content:center;}
#lightbox-overlay.open{display:flex;animation:fadeIn .2s ease;}
#lightbox-overlay img{max-width:90vw;max-height:88vh;object-fit:contain;border-radius:var(--r10);}
#lightbox-close{position:fixed;top:1rem;right:1rem;background:rgba(255,255,255,.15);border:none;color:#fff;width:40px;height:40px;border-radius:50%;font-size:1.2rem;cursor:pointer;}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.site-footer{background:#0d1433;color:rgba(255,255,255,.45);}
.ft-brand{font-family:'Syne',sans-serif;color:#fff;font-size:1.1rem;font-weight:900;}
.ft-brand em{color:var(--gold);font-style:normal;}
.ft-desc{font-size:.8rem;line-height:1.65;margin-top:.45rem;max-width:270px;}
.ft-title{color:#fff;font-size:.77rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.68rem;}
.ft-links{list-style:none;}
.ft-links a{color:rgba(255,255,255,.38);font-size:.8rem;text-decoration:none;display:block;margin-bottom:.35rem;transition:all var(--tr);}
.ft-links a:hover{color:var(--gold);padding-left:.22rem;}
.ft-social{display:flex;gap:.38rem;flex-wrap:wrap;margin-top:.7rem;}
.ft-social a{color:rgba(255,255,255,.38);font-size:.77rem;text-decoration:none;padding:.25rem .58rem;border:1px solid rgba(255,255,255,.1);border-radius:var(--r4);transition:all var(--tr);}
.ft-social a:hover{color:var(--gold);border-color:rgba(253,216,53,.4);}
.ft-bottom{border-top:1px solid rgba(255,255,255,.07);padding:.85rem 0;display:flex;justify-content:space-between;align-items:center;font-size:.75rem;flex-wrap:wrap;gap:.38rem;}
.pwa-banner{background:var(--navy-m);color:#fff;padding:.55rem 1rem;display:flex;align-items:center;gap:.8rem;justify-content:space-between;flex-wrap:wrap;}
.pwa-banner p{font-size:.82rem;margin:0;}
.pwa-btn{background:var(--gold);color:var(--navy);border:none;padding:.3rem .82rem;border-radius:var(--r4);font-weight:800;font-size:.78rem;cursor:pointer;}
.pwa-close{background:none;border:none;color:rgba(255,255,255,.5);font-size:.95rem;cursor:pointer;}
@media(max-width:900px){.msg-layout{grid-template-columns:1fr;height:auto;}.msg-sidebar{max-height:240px;}.msg-main{min-height:350px;}.ms-aside{position:static;}}
@media(max-width:768px){.panel-layout{flex-direction:column;}.sidebar{width:100%;min-height:auto;}.cat-grid{grid-template-columns:repeat(auto-fill,minmax(95px,1fr));gap:.45rem;}.biz-grid{grid-template-columns:1fr 1fr;gap:.6rem;}.hero-body{padding:1.8rem 0 1.5rem;}.ms-cover,.swiper-cover,.swiper-cover .swiper-slide{height:180px!important;}.swiper-cover .swiper-slide img{height:180px!important;}.ms-cover img.cover-img,.ms-cover .cover-emoji{height:180px;}.biz-img-wrap,.biz-img-real,.biz-emoji-box{height:120px;}.fav-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:480px){.biz-grid{grid-template-columns:1fr;}.ms-logo{margin-top:-33px;width:66px;height:66px;font-size:2rem;}.ms-name{font-size:1.1rem;}.nav-search{display:none;}.fav-grid{grid-template-columns:1fr;}}

/* ── COMPATIBILIDAD PANEL: clases heredadas ── */
.panel-sidebar{width:220px;background:var(--navy);flex-shrink:0;}
/* stat-card aliases */
.stat-val{font-family:'Syne',sans-serif;font-size:1.75rem;color:var(--navy);font-weight:800;}
.stat-lbl{color:var(--txm);font-size:.78rem;margin-top:.1rem;}
.stat-card.teal .stat-val,.stat-card.teal .v{color:#00796b;}
.stat-card.teal{border-left-color:#00796b;}
.stat-card.coral .stat-val,.stat-card.coral .v{color:#d84315;}
.stat-card.coral{border-left-color:#d84315;}
.stat-card.amber .stat-val,.stat-card.amber .v{color:#f57f17;}
.stat-card.amber{border-left-color:#f57f17;}
/* btn-coral, btn-ocean */
.btn-coral{background:#ef5350;color:#fff;display:inline-flex;align-items:center;gap:.4rem;border:none;border-radius:var(--r6);font-weight:700;font-size:.88rem;cursor:pointer;transition:all var(--tr);text-decoration:none;padding:.52rem 1.2rem;white-space:nowrap;}
.btn-coral:hover{background:#c62828;color:#fff;text-decoration:none;}
.btn-ocean{background:#1565c0;color:#fff;display:inline-flex;align-items:center;gap:.4rem;border:none;border-radius:var(--r6);font-weight:700;font-size:.88rem;cursor:pointer;transition:all var(--tr);text-decoration:none;padding:.52rem 1.2rem;white-space:nowrap;}
.btn-ocean:hover{background:#0d47a1;color:#fff;text-decoration:none;}
/* table-pc */
.table-pc{font-size:.84rem;width:100%;}
.table-pc thead{background:var(--navy);color:#fff;}
.table-pc th,.table-pc td{padding:.58rem .88rem;border-bottom:1px solid var(--brd);text-align:left;}
.table-pc tbody tr:hover{background:var(--navy-xl);}
/* card-pc */
.card-pc{background:var(--white);border:1px solid var(--brd);border-radius:var(--r12);box-shadow:var(--sh0);}
.card-header{background:var(--navy);color:#fff;padding:.65rem 1rem;border-radius:var(--r12) var(--r12) 0 0;font-family:'Syne',sans-serif;font-size:.9rem;font-weight:700;}
/* stars display */
.stars{color:var(--gold-d);letter-spacing:1px;}
/* Dark mode for legacy classes */
[data-theme="dark"] .card-pc,[data-theme="dark"] .table-pc thead{background:var(--white);}
[data-theme="dark"] .table-pc th,[data-theme="dark"] .table-pc td{border-color:var(--brd);}
[data-theme="dark"] .table-pc thead{background:#0d1f3c;}
[data-theme="dark"] .stat-val,[data-theme="dark"] .stat-card .stat-val{color:#90caf9;}
[data-theme="dark"] .stat-card.teal .stat-val{color:#80cbc4;}
[data-theme="dark"] .stat-card.coral .stat-val{color:#ef9a9a;}

/* ═══════════════════════════════════════════════════════════════
   COMPATIBILITY LAYER — mapea vars/clases antiguas al nuevo sistema
   ═══════════════════════════════════════════════════════════════ */
:root {
  /* Old variable aliases */
  --ocean:      #1a237e;   /* = --navy */
  --ocean-mid:  #3949ab;   /* = --navy-l */
  --coral:      #ef5350;   /* = --red-l */
  --teal:       #00796b;
  --amber:      #f9a825;   /* = --gold-d */
  --dark:       #212121;   /* = --tx */
  --sand:       #fffde7;   /* = --gold-bg */
  --text:       #212121;
  --text-muted: #757575;
  --border:     #e0e0e0;   /* = --brd */
}
/* Dark mode compat vars */
[data-theme="dark"] {
  --ocean:      #90caf9;
  --coral:      #ef9a9a;
  --teal:       #80cbc4;
  --amber:      #ffe082;
  --dark:       #e6edf3;
  --text:       #e6edf3;
  --text-muted: #8b949e;
  --border:     #30363d;
}

/* Missing Bootstrap-like utility classes */
.btn-outline-danger  { background:transparent; color:#ef5350; border:1.5px solid #ef5350; border-radius:var(--r6); padding:.52rem 1.2rem; font-weight:600; font-size:.88rem; cursor:pointer; transition:all var(--tr); display:inline-flex; align-items:center; gap:.4rem; text-decoration:none; }
.btn-outline-danger:hover  { background:#ef5350; color:#fff; text-decoration:none; }
.btn-outline-primary { background:transparent; color:var(--navy-l); border:1.5px solid var(--navy-l); border-radius:var(--r6); padding:.52rem 1.2rem; font-weight:600; font-size:.88rem; cursor:pointer; transition:all var(--tr); display:inline-flex; align-items:center; gap:.4rem; text-decoration:none; }
.btn-outline-primary:hover  { background:var(--navy); color:#fff; border-color:var(--navy); text-decoration:none; }
.btn-outline-secondary { background:transparent; color:var(--txm); border:1.5px solid var(--brd-d); border-radius:var(--r6); padding:.52rem 1.2rem; font-weight:600; font-size:.88rem; cursor:pointer; transition:all var(--tr); display:inline-flex; align-items:center; gap:.4rem; text-decoration:none; }
.btn-outline-secondary:hover { background:var(--bg); color:var(--tx); text-decoration:none; }
.btn-success { background:#2e7d32; color:#fff; border:none; border-radius:var(--r6); padding:.52rem 1.2rem; font-weight:600; font-size:.88rem; cursor:pointer; transition:all var(--tr); display:inline-flex; align-items:center; gap:.4rem; text-decoration:none; }
.btn-success:hover { background:#1b5e20; color:#fff; text-decoration:none; }
.btn-warning { background:#f9a825; color:#1a1a1a; border:none; border-radius:var(--r6); padding:.52rem 1.2rem; font-weight:700; font-size:.88rem; cursor:pointer; transition:all var(--tr); display:inline-flex; align-items:center; gap:.4rem; text-decoration:none; }
.btn-warning:hover { background:#f57f17; color:#fff; text-decoration:none; }
.btn-danger  { background:#ef5350; color:#fff; border:none; border-radius:var(--r6); padding:.52rem 1.2rem; font-weight:600; font-size:.88rem; cursor:pointer; transition:all var(--tr); display:inline-flex; align-items:center; gap:.4rem; text-decoration:none; }
.btn-danger:hover  { background:#c62828; color:#fff; text-decoration:none; }
.btn-secondary { background:var(--txm); color:#fff; border:none; border-radius:var(--r6); padding:.52rem 1.2rem; font-weight:600; font-size:.88rem; cursor:pointer; transition:all var(--tr); display:inline-flex; align-items:center; gap:.4rem; text-decoration:none; }
.btn-secondary:hover { background:var(--tx2); color:#fff; text-decoration:none; }

/* form-control-sm */
.form-control-sm { padding:.3rem .6rem !important; font-size:.82rem !important; }
.form-select-sm  { padding:.3rem .6rem !important; font-size:.82rem !important; }

/* Progress bars */
.progress { background:var(--brd); border-radius:var(--r4); overflow:hidden; height:8px; }
.progress-bar { background:var(--navy); height:100%; border-radius:var(--r4); transition:width .6s ease; }
.progress-bar.bg-success { background:var(--green); }
.progress-bar.bg-warning { background:var(--amber); }
.progress-bar.bg-danger  { background:var(--red-l); }

/* Badge variants */
.badge.bg-success { background:var(--green)!important; color:#fff; }
.badge.bg-warning { background:var(--amber)!important; color:#1a1a1a; }
.badge.bg-danger  { background:var(--red-l)!important; color:#fff; }
.badge.bg-primary { background:var(--navy)!important; color:#fff; }
.badge.bg-secondary { background:var(--txm)!important; color:#fff; }
.badge.bg-white   { background:#fff!important; color:var(--tx)!important; }
.badge.bg-info    { background:#0288d1!important; color:#fff; }

/* Rounded */
.rounded   { border-radius:var(--r8)!important; }
.rounded-lg{ border-radius:var(--r12)!important; }

/* Helpers */
.text-muted { color:var(--txm)!important; }
.text-dark  { color:var(--tx)!important; }
.text-white { color:#fff!important; }
.fw-bold    { font-weight:700!important; }
.fw-semibold{ font-weight:600!important; }

/* ── DARK MODE COMPLETO PARA ADMIN ─────────────────────── */
[data-theme="dark"] .modal-content        { background:var(--white); color:var(--tx); }
[data-theme="dark"] .modal-header         { border-color:var(--brd); }
[data-theme="dark"] .modal-footer         { border-color:var(--brd); background:var(--white); }
[data-theme="dark"] .modal-body           { background:var(--white); color:var(--tx); }
[data-theme="dark"] .dropdown-menu        { background:var(--white); border-color:var(--brd); }
[data-theme="dark"] .dropdown-item        { color:var(--tx); }
[data-theme="dark"] .dropdown-item:hover  { background:var(--navy-xl); }
[data-theme="dark"] .breadcrumb-item      { color:var(--txm); }
[data-theme="dark"] .breadcrumb-item.active { color:var(--tx); }
[data-theme="dark"] .nav-tabs             { border-color:var(--brd); }
[data-theme="dark"] .nav-tabs .nav-link   { color:var(--txm); }
[data-theme="dark"] .nav-tabs .nav-link.active { background:var(--white); color:var(--tx); border-color:var(--brd); }
[data-theme="dark"] .progress             { background:var(--brd); }
[data-theme="dark"] .list-group-item      { background:var(--white); border-color:var(--brd); color:var(--tx); }
[data-theme="dark"] .list-group-item:hover{ background:rgba(255,255,255,.04); }
[data-theme="dark"] .card-body,.card-footer{ background:var(--white); }
[data-theme="dark"] .card-header          { background:#0d1f3c; color:#e0e8ff; border-color:var(--brd); }
[data-theme="dark"] .alert-success        { background:var(--green-bg); border-color:var(--green); color:#a5d6a7; }
[data-theme="dark"] .alert-danger         { background:var(--red-bg); border-color:var(--red-l); color:#ef9a9a; }
[data-theme="dark"] .alert-warning        { background:#1a1400; border-color:var(--amber); color:#ffe082; }
[data-theme="dark"] .alert-info           { background:#0d1f3c; border-color:#0288d1; color:#81d4fa; }
[data-theme="dark"] .table-hover tbody tr:hover td { background:rgba(255,255,255,.04); }
[data-theme="dark"] .badge.bg-white       { background:rgba(255,255,255,.12)!important; color:var(--tx)!important; }
[data-theme="dark"] .input-group-text     { background:var(--white); border-color:var(--brd-d); color:var(--txm); }
[data-theme="dark"] h1,[data-theme="dark"] h2,[data-theme="dark"] h3,
[data-theme="dark"] h4,[data-theme="dark"] h5,[data-theme="dark"] h6 { color:var(--tx); }

/* ── NOTIFICACIONES — panel mejorado ── */
.notif-item{
  padding:.62rem .9rem;
  border-bottom:1px solid var(--brd);
  cursor:pointer;
  transition:background var(--tr);
  position:relative;
}
.notif-item:hover{background:var(--navy-xl);}
.notif-item.unread{
  background:var(--gold-bg);
  border-left:3px solid var(--gold);
}
[data-theme="dark"] .notif-item.unread{background:rgba(253,216,53,.08);}
[data-theme="dark"] .notif-item:hover{background:rgba(255,255,255,.04);}
.notif-item h6{
  font-size:.8rem;
  color:var(--navy);
  margin-bottom:.12rem;
  font-weight:700;
}
[data-theme="dark"] .notif-item h6{color:#90caf9;}
.notif-item p{font-size:.73rem;color:var(--txm);margin:0;}
.notif-item time{font-size:.68rem;color:var(--txl);}
/* Animación entrada al abrir dropdown */
#notifPanel.show{animation:slideDown .2s ease;}
@keyframes slideDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
