/* ===== NUBOGO APP CSS v3.0 - Simplificado & Mejorado ===== */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&family=Syne:wght@700;800&display=swap');

:root {
  --primary: #2563EB;
  --primary-dark: #1D4ED8;
  --primary-light: #EFF6FF;
  --secondary: #84CC16;
  --success: #16a34a;
  --danger: #dc2626;
  --warning: #f59e0b;
  --info: #0ea5e9;
  --dark: #0f172a;
  --gray: #64748b;
  --gray-light: #94a3b8;
  --bg: #f0f4f8;
  --surface: #ffffff;
  --surface2: #f8fafc;
  --border: #e2e8f0;
  --text: #0f172a;
  --text2: #334155;
  --text3: #64748b;
  --shadow: 0 1px 8px rgba(0,0,0,.07);
  --shadow-md: 0 4px 20px rgba(0,0,0,.10);
  --shadow-lg: 0 8px 40px rgba(0,0,0,.14);
  --radius: 14px;
  --radius-sm: 10px;
  --radius-xs: 6px;
  --nav-h: 60px;
  --bnav-h: 68px;
}

/* === DARK MODE === */
body.dark {
  --bg: #0f172a;
  --surface: #1e293b;
  --surface2: #162033;
  --border: #334155;
  --text: #f1f5f9;
  --text2: #cbd5e1;
  --text3: #94a3b8;
  --shadow: 0 1px 8px rgba(0,0,0,.25);
  --shadow-md: 0 4px 20px rgba(0,0,0,.30);
  --primary-light: #1e3a8a22;
}

/* === RESET === */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{font-family:'Poppins',sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased;transition:background .3s,color .3s;}
button{cursor:pointer;border:none;font-family:inherit;background:none;}
input,textarea,select{font-family:inherit;}
a{text-decoration:none;color:inherit;}
img{max-width:100%;display:block;}
ul,ol{list-style:none;}
hr{border:none;border-top:1px solid var(--border);margin:12px 0;}

/* === BRAND === */
.logo{display:inline-flex;align-items:center;gap:.1em;line-height:1;user-select:none;}
.logo-mark{width:.9em;height:.9em;border-radius:.25em;background:linear-gradient(135deg,#2563EB,#06B6D4);display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:.5em;box-shadow:0 0 20px rgba(37,99,235,.35);margin-right:.1em;}
.logo-word{font-family:'Syne','Poppins',sans-serif;font-weight:800;letter-spacing:-.05em;color:var(--text);}
.logo-accent{color:#2563EB;position:relative;}
.logo-accent::after{content:'';width:.14em;height:.14em;border-radius:50%;background:#84CC16;position:absolute;right:-.15em;top:.08em;}
.logo-on-dark .logo-word{color:#fff;}
.logo-on-dark .logo-accent{color:#93C5FD;}

/* === SPLASH === */
#splash{position:fixed;inset:0;background:linear-gradient(135deg,#0f172a,#1e293b);display:flex;align-items:center;justify-content:center;z-index:9999;flex-direction:column;gap:20px;}
.splash-logo.logo{font-size:72px;}
.splash-sub{font-size:11px;letter-spacing:4px;text-transform:uppercase;color:#64748b;}
.splash-bar{width:180px;height:3px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden;margin-top:8px;}
.splash-fill{width:0;height:100%;background:linear-gradient(90deg,var(--primary),var(--secondary));border-radius:2px;animation:splashLoad 2s ease forwards;}
@keyframes splashLoad{to{width:100%;}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
@keyframes pulse{0%,100%{transform:scale(1);}50%{transform:scale(1.04);}}
@keyframes slideUp{from{transform:translateY(30px);opacity:0;}to{transform:translateY(0);opacity:1;}}
@keyframes scaleIn{from{transform:scale(0);}to{transform:scale(1);}}
@keyframes truckMove{0%{left:8%;}50%{left:82%;}51%{left:82%;transform:translateY(-50%) scaleX(-1);}100%{left:8%;transform:translateY(-50%) scaleX(-1);}}

/* === LOGIN === */
#loginScreen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--bg);}
.login-wrap{width:100%;max-width:420px;animation:fadeUp .5s ease;}
.login-header{text-align:center;margin-bottom:28px;}
.login-logo.logo{font-size:52px;justify-content:center;}
.login-sub{color:var(--text3);font-size:13px;margin-top:6px;}
.login-box{background:var(--surface);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-md);}
.tabs{display:flex;background:var(--bg);border-radius:var(--radius-sm);padding:4px;gap:4px;margin-bottom:20px;}
.tab{flex:1;padding:9px;border-radius:var(--radius-xs);font-size:13px;font-weight:500;color:var(--text3);transition:.2s;text-align:center;}
.tab.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow);}

/* === FORM === */
.field{margin-bottom:14px;}
.field label{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:5px;text-transform:uppercase;letter-spacing:.3px;}
.field input,.field select,.field textarea{width:100%;padding:11px 14px;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:14px;background:var(--surface);color:var(--text);transition:.2s;outline:none;}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.12);}
.field-row{display:flex;gap:12px;}
.field-row .field{flex:1;}
.field-hint{font-size:11px;color:var(--text3);margin-top:3px;}
.field-error{font-size:11px;color:var(--danger);margin-top:3px;display:none;}
.field.has-error input{border-color:var(--danger);}
.field.has-error .field-error{display:block;}

/* === ROLE SELECT === */
.role-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:14px 0;}
.role-card{text-align:center;padding:14px 8px;border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:.25s;background:var(--surface);}
.role-card i{font-size:22px;color:var(--text3);display:block;margin-bottom:6px;transition:.25s;}
.role-card span{font-size:11px;font-weight:600;display:block;color:var(--text2);}
.role-card.active{border-color:var(--primary);background:var(--primary-light);}
.role-card.active i{color:var(--primary);}
.role-card:hover:not(.active){border-color:var(--primary);opacity:.8;}

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:12px 20px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;transition:.2s;cursor:pointer;text-align:center;}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;width:100%;padding:14px;}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 15px rgba(37,99,235,.4);}
.btn-secondary{background:var(--secondary);color:#fff;width:100%;}
.btn-success{background:var(--success);color:#fff;}
.btn-danger{background:var(--danger);color:#fff;padding:10px 20px;}
.btn-outline{border:2px solid var(--primary);color:var(--primary);background:transparent;padding:9px 16px;}
.btn-outline:hover{background:var(--primary);color:#fff;}
.btn-ghost{color:var(--text3);background:var(--surface2);padding:9px 16px;}
.btn-icon{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:17px;}
.btn-sm{padding:7px 14px;font-size:12px;}
.btn-block{width:100%;}
.btn-whatsapp{background:#25D366;color:#fff;}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;}

/* === SOCIAL LOGIN === */
.social-row{display:flex;gap:10px;justify-content:center;margin-top:16px;}
.btn-social{width:46px;height:46px;border-radius:50%;border:2px solid var(--border);background:var(--surface);font-size:17px;display:flex;align-items:center;justify-content:center;transition:.2s;}
.btn-social:hover{transform:scale(1.08);}
.btn-social.google{color:#db4437;}
.btn-social.facebook{color:#4267b2;}
.btn-social.apple{color:var(--text);}

/* === TOP NAV === */
.top-nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);background:var(--surface);display:flex;align-items:center;justify-content:space-between;padding:0 14px;box-shadow:0 1px 10px rgba(0,0,0,.07);z-index:4000;}
.nav-left,.nav-right{display:flex;align-items:center;gap:4px;}
.nav-btn{position:relative;width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--text);transition:.2s;}
.nav-btn:hover{background:var(--surface2);}
.badge{position:absolute;top:2px;right:2px;background:var(--danger);color:#fff;font-size:9px;font-weight:700;padding:1px 4px;border-radius:10px;min-width:15px;text-align:center;line-height:1.4;}
.nav-logo.logo{font-size:26px;}

/* === SIDEBAR === */
.sidebar{position:fixed;top:0;left:0;width:min(88vw,300px);height:100dvh;background:var(--surface);z-index:6000;transform:translateX(calc(-100% - 10px));transition:transform .28s cubic-bezier(.4,0,.2,1);overflow-y:auto;box-shadow:var(--shadow-lg);}
.sidebar.open{transform:translateX(0);}
.sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:5900;display:none;backdrop-filter:blur(2px);}
.sidebar-overlay.show{display:block;}
.sidebar-head{background:linear-gradient(135deg,var(--primary),#1e3a8a);padding:24px 20px;text-align:center;color:#fff;}
.sidebar-avatar{font-size:46px;margin-bottom:6px;}
.sidebar-name{font-size:16px;font-weight:600;margin-bottom:4px;}
.sidebar-role{font-size:11px;background:rgba(255,255,255,.2);padding:3px 10px;border-radius:20px;display:inline-block;}
.sidebar-nav{padding:8px 0;}
.sidebar-nav a{display:flex;align-items:center;gap:12px;padding:13px 20px;font-size:14px;color:var(--text2);transition:.18s;cursor:pointer;}
.sidebar-nav a:hover{background:var(--primary-light);color:var(--primary);}
.sidebar-nav a.active{background:var(--primary-light);color:var(--primary);font-weight:600;border-right:3px solid var(--primary);}
.sidebar-nav a i{width:18px;text-align:center;font-size:15px;}
.sidebar-nav .divider{height:1px;background:var(--border);margin:6px 0;}
.nav-logout{color:var(--danger)!important;}

/* === BOTTOM NAV === */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--bnav-h);background:var(--surface);display:flex;align-items:center;justify-content:space-around;padding:0 4px 8px;box-shadow:0 -1px 10px rgba(0,0,0,.07);z-index:3500;}
.bnav-item{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;font-weight:500;color:var(--text3);padding:6px 10px;border-radius:12px;transition:.2s;position:relative;min-width:50px;}
.bnav-item i{font-size:19px;}
.bnav-item.active{color:var(--primary);}
.bnav-item.active::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:28px;height:3px;background:var(--primary);border-radius:0 0 4px 4px;}

/* === MAIN CONTENT === */
.main{margin-top:var(--nav-h);padding:14px;padding-bottom:calc(var(--bnav-h) + 10px);min-height:calc(100vh - var(--nav-h));}

/* === CARDS === */
.card{background:var(--surface);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);margin-bottom:14px;}
.card:hover{box-shadow:var(--shadow-md);}
.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;}

/* === HERO BANNER === */
.hero{border-radius:var(--radius);padding:22px;color:#fff;margin-bottom:18px;position:relative;overflow:hidden;}
.hero h2{font-size:18px;font-weight:700;margin-bottom:4px;}
.hero p{font-size:12px;opacity:.85;margin-bottom:14px;line-height:1.5;}
.hero::after{content:'';position:absolute;right:-15px;bottom:-15px;width:100px;height:100px;background:rgba(255,255,255,.06);border-radius:50%;}

/* === SECTION TITLE === */
.section-title{font-size:16px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px;margin-bottom:12px;}
.section-title i{color:var(--primary);}

/* === STATS GRID === */
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px;}
.stat-card{background:var(--surface);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);text-align:center;}
.stat-icon{font-size:26px;margin-bottom:6px;}
.stat-val{font-size:22px;font-weight:700;color:var(--text);}
.stat-label{font-size:11px;color:var(--text3);margin-top:2px;}
.stat-card.blue .stat-icon{color:var(--primary);}
.stat-card.green .stat-icon{color:var(--success);}
.stat-card.yellow .stat-icon{color:var(--warning);}
.stat-card.red .stat-icon{color:var(--danger);}

/* === SEARCH BAR === */
.search-wrap{display:flex;gap:8px;margin-bottom:16px;}
.search-wrap input{flex:1;padding:11px 14px;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:14px;background:var(--surface);color:var(--text);outline:none;transition:.2s;}
.search-wrap input:focus{border-color:var(--primary);}
.search-wrap button{padding:11px 16px;background:var(--primary);color:#fff;border-radius:var(--radius-sm);font-size:16px;}

/* === CHIPS === */
.chips{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px;margin-bottom:14px;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
.chips::-webkit-scrollbar{display:none;}
.chip{white-space:nowrap;padding:7px 16px;border-radius:25px;border:2px solid var(--border);font-size:12px;font-weight:600;background:var(--surface);color:var(--text2);cursor:pointer;transition:.2s;}
.chip.active{background:var(--primary);color:#fff;border-color:var(--primary);}
.chip:hover:not(.active){border-color:var(--primary);}

/* === CATEGORIES GRID === */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px;margin-bottom:18px;}
.cat-item{text-align:center;padding:14px 8px 12px;border-radius:var(--radius-sm);background:var(--surface);border:2px solid transparent;cursor:pointer;transition:.2s;box-shadow:var(--shadow);}
.cat-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);}
.cat-item.active{border-color:var(--primary);}
.cat-item i{font-size:22px;display:block;margin-bottom:5px;}
.cat-item span{font-size:10px;font-weight:600;line-height:1.2;display:block;color:var(--text2);}

/* === PROVIDER CARD === */
.prov-card{background:var(--surface);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow);display:flex;gap:12px;margin-bottom:10px;cursor:pointer;transition:.2s;}
.prov-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px);}
.prov-avatar{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px;flex-shrink:0;}
.prov-info{flex:1;min-width:0;}
.prov-info h4{font-size:14px;font-weight:600;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.prov-specialty{font-size:12px;color:var(--text3);margin-bottom:5px;}
.prov-meta{display:flex;gap:10px;font-size:11px;flex-wrap:wrap;}
.prov-meta span{display:flex;align-items:center;gap:3px;}
.prov-right{display:flex;flex-direction:column;align-items:flex-end;justify-content:space-between;gap:6px;flex-shrink:0;}
.prov-price{font-size:15px;font-weight:700;color:var(--success);}
.avail-dot{width:8px;height:8px;border-radius:50%;display:inline-block;}
.avail-dot.on{background:var(--success);}
.avail-dot.off{background:var(--text3);}

/* === PRODUCT CARD === */
.prod-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
.prod-card{background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);cursor:pointer;transition:.2s;}
.prod-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);}
.prod-img{height:130px;background:linear-gradient(135deg,var(--primary-light),#e0f2fe);display:flex;align-items:center;justify-content:center;font-size:44px;color:var(--primary);position:relative;}
.discount-badge{position:absolute;top:8px;right:8px;background:var(--danger);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:5px;}
.fav-btn{position:absolute;top:8px;left:8px;background:rgba(255,255,255,.9);width:28px;height:28px;border-radius:50%;color:var(--text3);font-size:13px;display:flex;align-items:center;justify-content:center;transition:.2s;}
.fav-btn.on{color:var(--danger);}
.prod-info{padding:10px 12px;}
.prod-info h4{font-size:12px;font-weight:600;margin-bottom:3px;line-height:1.3;}
.prod-brand{font-size:11px;color:var(--text3);margin-bottom:5px;}
.prod-price{display:flex;align-items:center;gap:6px;margin-bottom:4px;}
.prod-price .price{font-size:15px;font-weight:700;color:var(--primary);}
.prod-price .old-price{font-size:11px;color:var(--text3);text-decoration:line-through;}
.prod-stars{display:flex;align-items:center;gap:2px;font-size:10px;color:var(--text3);}
.prod-stars i{color:var(--warning);font-size:9px;}
.btn-add{width:100%;padding:9px;background:var(--primary);color:#fff;font-size:12px;font-weight:600;border-radius:0 0 var(--radius) var(--radius);display:flex;align-items:center;justify-content:center;gap:6px;}
.btn-add:hover{background:var(--primary-dark);}

/* === ORDER CARD === */
.order-card{background:var(--surface);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow);margin-bottom:10px;}
.order-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;}
.order-id{font-size:14px;font-weight:700;color:var(--primary);}
.status-badge{padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;}
.status-pending{background:#fef9c3;color:#854d0e;}
.status-confirmed{background:#dcfce7;color:#14532d;}
.status-shipping{background:#dbeafe;color:#1e3a8a;}
.status-delivered{background:#d1fae5;color:#065f46;}
.status-cancelled{background:#fee2e2;color:#7f1d1d;}
.order-items{font-size:13px;color:var(--text2);margin-bottom:6px;}
.order-foot{display:flex;justify-content:space-between;align-items:center;padding-top:8px;border-top:1px solid var(--border);}
.order-total{font-size:15px;font-weight:700;}
.order-date{font-size:11px;color:var(--text3);}

/* === MAP === */
.map-box{width:100%;height:320px;border-radius:var(--radius);overflow:hidden;background:linear-gradient(135deg,#e0f2fe,#dbeafe);position:relative;margin-bottom:10px;}
#serviceMap,#refaccionesMap,#trackingMap,#provMap{height:100%;width:100%;border-radius:var(--radius);}
.map-legend{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;}
.map-legend span{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border:1px solid var(--border);border-radius:999px;background:var(--surface);font-size:11px;color:var(--text2);}
.legend-dot{width:9px;height:9px;border-radius:50%;display:inline-block;}
.legend-blue{background:#2563eb;}
.legend-green{background:#16a34a;}
.legend-red{background:#dc2626;}
.map-placeholder{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.map-placeholder::before{content:'\f0d1';font-family:'Font Awesome 6 Free','FontAwesome';font-weight:900;font-size:28px;color:var(--primary);position:absolute;top:50%;animation:truckMove 4s ease-in-out infinite;}
.map-placeholder::after{content:'';position:absolute;top:50%;left:8%;right:8%;height:3px;background:linear-gradient(90deg,var(--primary),var(--success));border-radius:2px;transform:translateY(-50%);opacity:.35;}

/* === TRACKING STEPS === */
.track-steps{display:flex;justify-content:space-between;position:relative;margin:18px 0;}
.track-steps::before{content:'';position:absolute;top:18px;left:10%;right:10%;height:3px;background:var(--border);}
.track-step{text-align:center;position:relative;z-index:1;flex:1;}
.step-icon{width:36px;height:36px;border-radius:50%;background:var(--border);display:flex;align-items:center;justify-content:center;margin:0 auto 6px;color:#fff;font-size:14px;transition:.3s;}
.track-step.done .step-icon{background:var(--success);}
.track-step.current .step-icon{background:var(--primary);}
.step-lbl{font-size:10px;color:var(--text3);}
.track-step.current .step-lbl{color:var(--primary);font-weight:600;}

/* === MODALS === */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:8000;display:flex;align-items:flex-end;padding:0;animation:fadeIn .2s;}
.modal-bg.center{align-items:center;padding:15px;}
.modal{background:var(--surface);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-height:92dvh;overflow-y:auto;animation:slideUp .3s ease;}
.modal-center{border-radius:var(--radius);max-width:460px;width:100%;}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:18px 18px 14px;border-bottom:1px solid var(--border);}
.modal-head h3{font-size:17px;font-weight:700;display:flex;align-items:center;gap:8px;}
.modal-close{width:32px;height:32px;border-radius:50%;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--text3);}
.modal-body{padding:18px;}

/* === PAYMENT === */
.payment-methods h4{font-size:14px;font-weight:600;margin-bottom:12px;}
.bank-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px;}
.bank-card{text-align:center;padding:12px 6px;border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:.2s;}
.bank-card:hover,.bank-card.active{border-color:var(--primary);background:var(--primary-light);}
.bank-logo{height:28px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;margin-bottom:4px;}
.bank-card span{font-size:10px;color:var(--text2);}
.bbva-bg{background:linear-gradient(135deg,#004481,#006cb5);}
.banamex-bg{background:linear-gradient(135deg,#003da5,#0066cc);}
.banorte-bg{background:linear-gradient(135deg,#c8102e,#e31837);}
.santander-bg{background:linear-gradient(135deg,#ec0000,#ff2020);}
.hsbc-bg{background:linear-gradient(135deg,#db0011,#ff1a2c);}
.scotia-bg{background:linear-gradient(135deg,#ec111a,#ff3040);}
.efectivo-bg{background:linear-gradient(135deg,#16a34a,#065f46);}
.card-visual{background:linear-gradient(135deg,var(--primary),#1e3a8a);border-radius:14px;padding:20px;color:#fff;aspect-ratio:1.6/1;max-width:320px;margin:0 auto 16px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:var(--shadow-lg);}
.card-chip{width:36px;height:26px;background:linear-gradient(135deg,#d4af37,#f5d060);border-radius:4px;}
.card-num{font-size:17px;letter-spacing:3px;font-family:'Courier New',monospace;text-align:center;}
.card-foot{display:flex;justify-content:space-between;font-size:9px;opacity:.8;}
.pay-summary{background:var(--surface2);border-radius:var(--radius-sm);padding:14px;margin-bottom:14px;}
.pay-row{display:flex;justify-content:space-between;padding:4px 0;font-size:13px;}
.pay-total{font-size:17px;font-weight:700;border-top:2px solid var(--border);padding-top:8px;margin-top:4px;}
.secure-note{text-align:center;font-size:11px;color:var(--text3);margin-top:10px;}

/* === SUCCESS === */
.success-screen{text-align:center;padding:20px;}
.success-icon{font-size:72px;color:var(--success);animation:scaleIn .5s ease;display:block;margin:0 auto 16px;}
.success-screen h2{color:var(--success);font-size:22px;margin-bottom:8px;}
.order-num-box{background:var(--surface2);padding:10px;border-radius:var(--radius-sm);font-size:16px;margin:12px 0;}

/* === RATING === */
.stars-row{display:flex;justify-content:center;gap:6px;font-size:38px;margin:14px 0;}
.stars-row i{color:var(--border);cursor:pointer;transition:.2s;}
.stars-row i.on{color:var(--warning);}

/* === NOTIFICATIONS === */
.notif-panel{position:fixed;top:var(--nav-h);right:0;width:340px;max-width:100%;max-height:calc(100vh - var(--nav-h));background:var(--surface);box-shadow:var(--shadow-lg);z-index:5000;overflow-y:auto;border-radius:0 0 0 var(--radius);animation:fadeIn .2s;}
.notif-head{display:flex;justify-content:space-between;align-items:center;padding:14px;border-bottom:1px solid var(--border);}
.notif-item{display:flex;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border);transition:.18s;cursor:pointer;}
.notif-item:hover{background:var(--surface2);}
.notif-item.unread{background:var(--primary-light);}
.notif-item i{font-size:18px;margin-top:2px;}
.notif-item p{font-size:13px;margin-bottom:2px;}
.notif-item small{font-size:11px;color:var(--text3);}

/* === CHAT === */
.chat-panel{position:fixed;top:0;right:-100%;width:min(100%,400px);height:100dvh;background:var(--surface);z-index:7000;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);transition:right .3s ease;}
.chat-panel.open{right:0;}
.chat-head{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--primary);color:#fff;flex-shrink:0;}
.chat-head h4{font-size:14px;font-weight:600;}
.chat-head small{font-size:11px;opacity:.8;}
.chat-msgs{flex:1;padding:14px;overflow-y:auto;background:var(--surface2);display:flex;flex-direction:column;gap:10px;}
.msg{display:flex;}
.msg.sent{justify-content:flex-end;}
.bubble{max-width:78%;padding:9px 13px;border-radius:14px;font-size:13px;line-height:1.4;}
.msg.recv .bubble{background:var(--surface);border-bottom-left-radius:3px;box-shadow:var(--shadow);}
.msg.sent .bubble{background:var(--primary);color:#fff;border-bottom-right-radius:3px;}
.msg-time{font-size:10px;opacity:.6;display:block;margin-top:3px;}
.chat-input-row{display:flex;gap:8px;padding:10px 14px;border-top:1px solid var(--border);flex-shrink:0;}
.chat-input-row input{flex:1;padding:10px 14px;border:2px solid var(--border);border-radius:25px;font-size:13px;background:var(--surface);color:var(--text);outline:none;transition:.2s;}
.chat-input-row input:focus{border-color:var(--primary);}
.chat-send{width:38px;height:38px;border-radius:50%;background:var(--primary);color:#fff;font-size:15px;display:flex;align-items:center;justify-content:center;}

/* === TOAST === */
#toast{position:fixed;bottom:calc(var(--bnav-h) + 12px);left:50%;transform:translateX(-50%) translateY(10px);background:var(--dark);color:#fff;padding:11px 22px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;z-index:9999;opacity:0;transition:opacity .3s,transform .3s;pointer-events:none;display:flex;align-items:center;gap:8px;max-width:90%;white-space:nowrap;}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
#toast.success{background:var(--success);}
#toast.error{background:var(--danger);}
#toast.warning{background:var(--warning);color:var(--dark);}

/* === TOGGLE === */
.toggle{width:46px;height:25px;border-radius:13px;background:var(--border);position:relative;cursor:pointer;transition:.25s;flex-shrink:0;}
.toggle.on{background:var(--primary);}
.toggle::after{content:'';position:absolute;top:3px;left:3px;width:19px;height:19px;border-radius:50%;background:#fff;transition:.25s;}
.toggle.on::after{left:24px;}

/* === CONFIG ITEMS === */
.config-item{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--border);cursor:pointer;}
.config-item:last-child{border:none;}
.config-left{display:flex;align-items:center;gap:12px;}
.config-left i{font-size:18px;color:var(--primary);width:22px;text-align:center;}
.config-left h4{font-size:14px;font-weight:500;}
.config-left p{font-size:12px;color:var(--text3);}
.config-right{color:var(--text3);}

/* === SUBPAGE HEADER === */
.subpage-head{display:flex;align-items:center;gap:12px;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--border);}
.back-btn{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--text);transition:.2s;flex-shrink:0;}
.back-btn:hover{background:var(--surface2);color:var(--primary);}
.subpage-head h2{font-size:17px;font-weight:700;}
.subpage-head p{font-size:12px;color:var(--text3);}

/* === ACCORDION === */
.accordion{background:var(--surface);border-radius:var(--radius-sm);margin-bottom:8px;box-shadow:var(--shadow);overflow:hidden;}
.accordion-btn{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;cursor:pointer;font-size:14px;font-weight:500;width:100%;text-align:left;color:var(--text);transition:background .18s;}
.accordion-btn:hover{background:var(--surface2);}
.accordion-btn.open{color:var(--primary);}
.accordion-btn i{font-size:11px;color:var(--text3);transition:transform .3s;}
.accordion-btn.open i{transform:rotate(180deg);}
.accordion-body{max-height:0;overflow:hidden;transition:max-height .3s ease;}
.accordion-body.open{max-height:500px;}
.accordion-inner{padding:0 18px 14px;font-size:13px;color:var(--text2);line-height:1.7;}

/* === TABLES === */
.table-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;font-size:13px;}
th{background:var(--surface2);padding:10px 14px;text-align:left;font-weight:600;color:var(--text);border-bottom:2px solid var(--border);}
td{padding:9px 14px;border-bottom:1px solid var(--border);}
tr:hover td{background:var(--primary-light);}

/* === REQUEST CARD (PROVIDER) === */
.req-card{background:var(--surface);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow);margin-bottom:10px;border-left:4px solid var(--primary);}
.req-card.urgent{border-left-color:var(--danger);}
.req-head{display:flex;justify-content:space-between;margin-bottom:6px;}
.req-type{font-size:11px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.5px;}
.req-time{font-size:11px;color:var(--text3);}
.req-card h4{font-size:14px;font-weight:600;margin-bottom:3px;}
.req-card p{font-size:12px;color:var(--text2);margin-bottom:8px;}
.req-foot{display:flex;justify-content:space-between;align-items:center;}
.req-price{font-size:16px;font-weight:700;color:var(--success);}
.req-actions{display:flex;gap:6px;}

/* === DEV SECTIONS === */
.dev-section{background:var(--surface);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);margin-bottom:12px;border-left:4px solid var(--gray);}
.dev-section.api{border-left-color:#8b5cf6;}
.dev-section.firebase{border-left-color:var(--warning);}
.dev-section.payment{border-left-color:var(--success);}
.dev-section.push{border-left-color:var(--danger);}
.dev-section.storage{border-left-color:var(--info);}
.dev-section h3{font-size:14px;font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:8px;}
.api-field{margin-bottom:10px;}
.api-field label{display:block;font-size:11px;font-weight:600;color:var(--text2);margin-bottom:3px;text-transform:uppercase;letter-spacing:.3px;}
.api-field input,.api-field select,.api-field textarea{width:100%;padding:9px 11px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;font-family:'Courier New',monospace;background:var(--surface2);color:var(--text);outline:none;transition:.2s;}
.api-field input:focus{border-color:var(--primary);}
.api-field .hint{font-size:10px;color:var(--text3);margin-top:2px;font-style:italic;}
.env-badge{display:inline-block;padding:3px 8px;border-radius:20px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;}
.env-dev{background:#dcfce7;color:#14532d;}
.env-staging{background:#fef9c3;color:#854d0e;}
.env-prod{background:#fee2e2;color:#7f1d1d;}

/* === CHART === */
.bar-chart{display:flex;align-items:flex-end;gap:6px;height:130px;padding:8px 0;}
.bar-col{flex:1;background:linear-gradient(to top,var(--primary),rgba(37,99,235,.6));border-radius:4px 4px 0 0;position:relative;min-width:16px;transition:.3s;}
.bar-col span{position:absolute;top:-16px;left:50%;transform:translateX(-50%);font-size:9px;font-weight:600;color:var(--text);}
.bar-labels{display:flex;gap:6px;}
.bar-labels div{flex:1;text-align:center;font-size:9px;color:var(--text3);}

/* === MISC === */
.empty{text-align:center;padding:40px 20px;}
.empty i{font-size:44px;color:var(--border);margin-bottom:12px;display:block;}
.empty p{font-size:14px;color:var(--text3);}
.tag{display:inline-block;padding:3px 10px;border-radius:15px;font-size:11px;font-weight:600;}
.tag-blue{background:#dbeafe;color:#1e3a8a;}
.tag-green{background:#dcfce7;color:#14532d;}
.tag-yellow{background:#fef9c3;color:#854d0e;}
.tag-red{background:#fee2e2;color:#7f1d1d;}
.text-success{color:var(--success);}
.text-primary{color:var(--primary);}
.text-warning{color:var(--warning);}
.text-danger{color:var(--danger);}
.text-muted{color:var(--text3);}
.mb-8{margin-bottom:8px;}
.mb-12{margin-bottom:12px;}
.mb-16{margin-bottom:16px;}
.mb-20{margin-bottom:20px;}
.mt-8{margin-top:8px;}
.mt-12{margin-top:12px;}
.mt-16{margin-top:16px;}
.flex{display:flex;}
.flex-center{display:flex;align-items:center;}
.flex-between{display:flex;justify-content:space-between;align-items:center;}
.gap-8{gap:8px;}
.gap-12{gap:12px;}
.w-full{width:100%;}

/* === PWA INSTALL BANNER === */
.install-banner{position:fixed;bottom:calc(var(--bnav-h) + 8px);left:12px;right:12px;background:var(--dark);color:#fff;border-radius:var(--radius);padding:14px 16px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-lg);z-index:3000;animation:slideUp .4s ease;}
.install-banner i{font-size:22px;color:var(--secondary);flex-shrink:0;}
.install-banner-text{flex:1;}
.install-banner-text h4{font-size:13px;font-weight:600;}
.install-banner-text p{font-size:11px;opacity:.75;margin-top:1px;}
.install-btn{background:var(--primary);color:#fff;padding:8px 14px;border-radius:var(--radius-sm);font-size:12px;font-weight:600;flex-shrink:0;}
.install-dismiss{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;color:rgba(255,255,255,.6);flex-shrink:0;}

/* === PROVIDER DETAIL HERO === */
.prov-detail-hero{background:linear-gradient(135deg,var(--primary),#1e3a8a);border-radius:var(--radius);padding:22px;color:#fff;text-align:center;margin-bottom:14px;position:relative;overflow:hidden;}
.prov-detail-avatar{width:72px;height:72px;border-radius:50%;border:3px solid rgba(255,255,255,.3);background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 10px;}
.prov-detail-hero h2{font-size:17px;font-weight:700;margin-bottom:3px;}
.prov-detail-hero p{font-size:12px;opacity:.85;}
.prov-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px;}
.prov-action-btn{display:flex;flex-direction:column;align-items:center;gap:5px;padding:12px 8px;border-radius:var(--radius-sm);font-size:11px;font-weight:600;background:var(--surface);box-shadow:var(--shadow);}
.prov-action-btn i{font-size:18px;}

/* === SERVICE LIST === */
.svc-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:var(--surface2);border-radius:var(--radius-sm);border:2px solid transparent;cursor:pointer;transition:.2s;margin-bottom:8px;}
.svc-item.active{border-color:var(--primary);background:var(--primary-light);}
.svc-item-left{display:flex;align-items:center;gap:10px;flex:1;}
.svc-item-left i{color:var(--primary);font-size:15px;width:18px;text-align:center;}
.svc-name{font-size:13px;font-weight:600;}
.svc-desc{font-size:11px;color:var(--text3);}
.svc-price{font-size:14px;font-weight:700;color:var(--success);}

/* === STATUS DOT === */
.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;}
.dot-green{background:var(--success);}
.dot-red{background:var(--danger);}
.dot-yellow{background:var(--warning);}

/* === RESPONSIVE === */
@media(min-width:768px){
  .main{max-width:800px;margin-left:auto;margin-right:auto;padding-bottom:30px;}
  .bottom-nav{display:none;}
  .prod-grid{grid-template-columns:repeat(3,1fr);}
  .stats-grid{grid-template-columns:repeat(4,1fr);}
  .prov-actions{grid-template-columns:repeat(3,1fr);}
}
@media(min-width:1024px){
  .prod-grid{grid-template-columns:repeat(4,1fr);}
}
@media(max-width:380px){
  .bank-grid{grid-template-columns:repeat(2,1fr);}
  .cat-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));}
  .role-grid{grid-template-columns:repeat(3,1fr);}
}

/* === LEAFLET POPUPS === */
.leaflet-popup-content-wrapper{background:#fff!important;color:#111!important;font-size:13px;border-radius:10px!important;box-shadow:0 4px 18px rgba(0,0,0,.3)!important;}
.leaflet-popup-content-wrapper *{color:#222!important;}
.leaflet-popup-tip{background:#fff!important;}
.leaflet-popup-content{margin:10px 13px;}
body.dark .leaflet-control-zoom a,.dark .leaflet-bar a{background:#1e293b;color:#fff;border-bottom-color:#334155;}

/* ===== APP v3 COMPONENT STYLES ===== */

/* Splash */
.splash-screen{position:fixed;inset:0;background:linear-gradient(135deg,#0f172a,#1e3a8a);display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity .5s;}
.splash-screen.fade-out{opacity:0;pointer-events:none;}
.splash-content{text-align:center;animation:fadeUp .6s ease;}
.splash-logo{font-size:72px;color:#fff;margin-bottom:12px;}
.splash-title{font-family:'Syne',sans-serif;font-size:38px;color:#fff;font-weight:800;letter-spacing:-.02em;margin-bottom:4px;}
.splash-subtitle{color:rgba(255,255,255,.6);font-size:13px;letter-spacing:2px;text-transform:uppercase;}
.splash-loader{width:160px;height:3px;background:rgba(255,255,255,.15);border-radius:2px;margin:20px auto 0;overflow:hidden;}
.splash-bar{height:100%;background:linear-gradient(90deg,#2563EB,#06B6D4);border-radius:2px;animation:splashLoad 1.6s ease forwards;}

/* Auth Screen */
.auth-screen{min-height:100vh;display:flex;align-items:flex-start;justify-content:center;padding:32px 20px 48px;background:var(--bg);overflow-y:auto;}
.auth-container{width:100%;max-width:420px;animation:fadeUp .4s ease;}
.auth-logo{display:flex;align-items:center;justify-content:center;gap:10px;font-family:'Syne',sans-serif;font-size:32px;font-weight:800;color:var(--primary);margin-bottom:4px;}
.auth-logo i{font-size:28px;}
.auth-tagline{text-align:center;color:var(--text3);font-size:13px;margin-bottom:22px;}
.auth-tabs{display:flex;background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-sm);padding:4px;gap:4px;margin-bottom:18px;}
.auth-tab{flex:1;padding:10px;border-radius:var(--radius-xs);font-size:13px;font-weight:600;color:var(--text3);transition:.2s;background:none;text-align:center;}
.auth-tab.active{background:var(--primary);color:#fff;}
.auth-panel{background:var(--surface);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-md);}
.login-roles{margin-top:16px;}
.roles-label{font-size:12px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.4px;margin-bottom:10px;}
.roles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.role-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:11px;font-weight:700;color:var(--text2);background:var(--surface);transition:.2s;}
.role-btn:hover{border-color:var(--primary);color:var(--primary);}
.role-btn i{font-size:20px;}
.role-btn.role-cliente{color:#2563EB;border-color:#2563EB22;background:#eff6ff;}
.role-btn.role-proveedor{color:#16a34a;border-color:#16a34a22;background:#f0fdf4;}
.role-btn.role-dev{color:#8b5cf6;border-color:#8b5cf622;background:#f5f3ff;}

/* Form */
.form-group{margin-bottom:14px;}
.form-label{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:5px;text-transform:uppercase;letter-spacing:.3px;}
.form-input{width:100%;padding:11px 14px;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:14px;background:var(--surface);color:var(--text);transition:.2s;outline:none;}
.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.1);}
select.form-input{cursor:pointer;}
textarea.form-input{resize:vertical;min-height:80px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.form-row-btns{display:flex;gap:10px;align-items:center;margin-top:6px;}
.mt-1{margin-top:8px;}

/* Buttons v3 */
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:7px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;padding:13px 20px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;transition:.2s;border:none;cursor:pointer;}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(37,99,235,.4);}
.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:7px;background:var(--success);color:#fff;padding:12px 20px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;border:none;cursor:pointer;}
.btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:2px solid var(--primary);color:var(--primary);background:transparent;padding:10px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:.2s;}
.btn-outline:hover{background:var(--primary);color:#fff;}
.btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:var(--danger);color:#fff;padding:9px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;border:none;cursor:pointer;}
.btn-sm{padding:7px 13px!important;font-size:12px!important;}
.btn-xs{padding:5px 10px!important;font-size:11px!important;}
.btn-lg{padding:15px 24px!important;font-size:15px!important;}
.btn-full{width:100%;}
.link-btn{background:none;border:none;color:var(--primary);font-size:13px;font-weight:600;cursor:pointer;padding:4px 8px;}

/* Nav */
.top-nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);background:var(--surface);border-bottom:1px solid var(--border);z-index:4000;}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:100%;padding:0 14px;}
.nav-actions{display:flex;align-items:center;gap:6px;}
.nav-icon-btn{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--text2);background:none;border:none;cursor:pointer;position:relative;transition:.2s;}
.nav-icon-btn:hover{background:var(--surface2);}
.cart-btn{position:relative;}
.cart-badge{position:absolute;top:0;right:0;background:var(--danger);color:#fff;font-size:9px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px;}
.nav-user{display:flex;align-items:center;gap:7px;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:.2s;}
.nav-user:hover{background:var(--surface2);}
.nav-avatar{width:28px;height:28px;border-radius:50%;background:var(--primary);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;}
.nav-name{font-size:12px;font-weight:600;color:var(--text2);max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}

/* Bottom Nav */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--bnav-h);background:var(--surface);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-around;padding:0 4px 6px;z-index:3500;}
.bnav-item{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;font-weight:500;color:var(--text3);padding:6px 10px;border-radius:12px;transition:.2s;min-width:50px;background:none;border:none;cursor:pointer;position:relative;}
.bnav-item i{font-size:20px;}
.bnav-item.active{color:var(--primary);}
.bnav-item.active::after{content:'';position:absolute;top:-1px;left:50%;transform:translateX(-50%);width:26px;height:3px;background:var(--primary);border-radius:0 0 3px 3px;}

/* Main Content */
.main-content{margin-top:var(--nav-h);padding-bottom:calc(var(--bnav-h) + 10px);min-height:calc(100dvh - var(--nav-h));}
.section-wrap{max-width:860px;margin:0 auto;padding:14px;}
.loading-spinner{display:flex;align-items:center;justify-content:center;padding:60px;font-size:28px;color:var(--primary);}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;}
.badge-success{background:#dcfce7;color:#14532d;}
.badge-danger{background:#fee2e2;color:#7f1d1d;}
.badge-warning{background:#fef9c3;color:#854d0e;}
.badge-primary{background:#dbeafe;color:#1e3a8a;}
.badge-info{background:#e0f2fe;color:#0c4a6e;}
.badge-gray{background:var(--surface2);color:var(--text3);}
.role-badge{padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;}
.role-cliente{background:#dbeafe;color:#1e3a8a;}
.role-proveedor{background:#dcfce7;color:#14532d;}
.role-desarrollador,.role-dev{background:#f5f3ff;color:#5b21b6;}
.role-badge-sm{font-size:10px;padding:2px 7px;border-radius:10px;}

/* Hero Card */
.hero-card{border-radius:var(--radius);overflow:hidden;margin-bottom:16px;}
.hero-bg{padding:22px;position:relative;overflow:hidden;min-height:130px;display:flex;align-items:center;justify-content:space-between;}
.hero-content h2{font-size:18px;font-weight:700;color:#fff;margin-bottom:4px;}
.hero-content p{font-size:12px;color:rgba(255,255,255,.8);margin-bottom:10px;}
.hero-search{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);border-radius:25px;padding:8px 14px;backdrop-filter:blur(6px);}
.hero-search i{color:rgba(255,255,255,.8);font-size:13px;}
.hero-search input{background:none;border:none;color:#fff;font-size:13px;outline:none;width:160px;}
.hero-search input::placeholder{color:rgba(255,255,255,.6);}
.hero-icon{font-size:52px;color:rgba(255,255,255,.25);}

/* Category Grid */
.cats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;margin-bottom:18px;}
.cat-chip{display:flex;flex-direction:column;align-items:center;gap:5px;padding:12px 8px;border-radius:var(--radius-sm);border:2px solid transparent;background:var(--surface);box-shadow:var(--shadow);font-size:10px;font-weight:600;color:var(--text2);cursor:pointer;transition:.2s;}
.cat-chip i{font-size:20px;color:var(--chip-c,var(--primary));}
.cat-chip:hover,.cat-chip.active{border-color:var(--chip-c,var(--primary));background:color-mix(in srgb,var(--chip-c,var(--primary)) 8%,transparent);}
.cats-scroll{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px;margin-bottom:14px;scrollbar-width:none;}
.cats-scroll::-webkit-scrollbar{display:none;}
.cat-pill{white-space:nowrap;padding:7px 14px;border-radius:25px;border:2px solid var(--border);font-size:12px;font-weight:600;background:var(--surface);color:var(--text2);cursor:pointer;transition:.2s;display:inline-flex;align-items:center;gap:6px;}
.cat-pill.active{background:var(--chip-c,var(--primary));color:#fff;border-color:var(--chip-c,var(--primary));}

/* Section title */
.section-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;margin-top:18px;}
.section-title-row h3{font-size:15px;font-weight:700;color:var(--text);}
.section-sub-title{font-size:15px;font-weight:700;margin:16px 0 10px;}
.section-header{display:flex;align-items:center;gap:14px;padding:14px;background:var(--surface);border-radius:var(--radius);margin-bottom:14px;box-shadow:var(--shadow);}
.section-header i{font-size:26px;}
.section-header h2{font-size:16px;font-weight:700;margin-bottom:2px;}
.section-header p{font-size:12px;color:var(--text3);}
.page-title{font-size:18px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:9px;}
.page-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}

/* Tabs */
.section-tabs{display:flex;background:var(--surface);border-radius:var(--radius-sm);padding:4px;gap:4px;margin-bottom:14px;border:1px solid var(--border);}
.tab-btn{flex:1;padding:9px;border-radius:var(--radius-xs);font-size:12px;font-weight:600;color:var(--text3);background:none;border:none;cursor:pointer;transition:.2s;}
.tab-btn.active{background:var(--primary);color:#fff;}

/* Cards Scroll */
.cards-scroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;margin-bottom:4px;scrollbar-width:none;}
.cards-scroll::-webkit-scrollbar{display:none;}
.cards-scroll .prov-card,.cards-scroll .part-card{min-width:220px;}
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-bottom:8px;}

/* Provider Card v3 */
.prov-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;cursor:pointer;transition:.2s;flex-shrink:0;}
.prov-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);}
.prov-card-header{padding:18px;position:relative;display:flex;align-items:center;justify-content:space-between;}
.prov-card-header i{font-size:28px;}
.fav-btn{background:rgba(255,255,255,.9);border:none;width:28px;height:28px;border-radius:50%;cursor:pointer;color:var(--text3);font-size:13px;display:flex;align-items:center;justify-content:center;transition:.2s;}
.fav-btn.active{color:var(--danger);}
.fav-btn-lg{background:rgba(255,255,255,.2);border:none;width:38px;height:38px;border-radius:50%;cursor:pointer;color:#fff;font-size:16px;display:flex;align-items:center;justify-content:center;transition:.2s;flex-shrink:0;}
.fav-btn-lg.active{background:var(--danger);color:#fff;}
.prov-card-body{padding:0 14px 14px;}
.prov-card-body h4{font-size:13px;font-weight:700;margin-bottom:3px;}
.prov-card-body p{font-size:11px;color:var(--text3);margin-bottom:7px;}
.prov-card-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.prov-card-footer{display:flex;align-items:center;justify-content:space-between;}
.rating-chip{font-size:11px;font-weight:600;color:var(--text2);display:inline-flex;align-items:center;gap:3px;}
.rating-chip i{font-size:10px;}
.reviews-count{font-size:11px;color:var(--text3);}
.price-tag{font-size:14px;font-weight:700;color:var(--success);}
.time-tag{font-size:11px;color:var(--text3);display:flex;align-items:center;gap:4px;}

/* Part Card v3 */
.parts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
.part-card{background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.2s;flex-shrink:0;}
.part-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);}
.part-card-img{padding:20px;display:flex;align-items:center;justify-content:center;font-size:40px;position:relative;}
.discount-badge{position:absolute;top:8px;right:8px;background:var(--danger);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:5px;}
.part-card-body{padding:10px 12px 12px;}
.part-brand{font-size:11px;color:var(--text3);margin-bottom:3px;display:block;}
.part-card-body h4{font-size:12px;font-weight:600;line-height:1.3;margin-bottom:6px;}
.part-prices{display:flex;align-items:center;gap:7px;margin-bottom:4px;}
.part-price{font-size:15px;font-weight:700;color:var(--primary);}
.part-old-price{font-size:11px;color:var(--text3);text-decoration:line-through;}
.part-meta{margin-bottom:8px;}

/* Provider Detail */
.back-btn{display:inline-flex;align-items:center;gap:7px;padding:7px 12px;border-radius:var(--radius-sm);background:var(--surface2);border:none;cursor:pointer;font-size:13px;font-weight:600;color:var(--text2);margin-bottom:14px;transition:.2s;}
.back-btn:hover{background:var(--primary-light);color:var(--primary);}
.provider-hero{display:flex;align-items:center;gap:14px;padding:18px;border-radius:var(--radius);margin-bottom:14px;color:#fff;}
.provider-avatar{width:60px;height:60px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;}
.provider-hero-info{flex:1;min-width:0;}
.provider-hero-info h2{font-size:16px;font-weight:700;margin-bottom:2px;}
.provider-hero-info p{font-size:12px;opacity:.85;margin-bottom:5px;}
.provider-meta-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.detail-info-grid{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;}
.info-chip{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text2);padding:7px 12px;background:var(--surface);border-radius:var(--radius-xs);border:1px solid var(--border);}
.info-chip i{color:var(--primary);width:14px;text-align:center;}
.provider-bio{font-size:13px;color:var(--text2);line-height:1.6;margin-bottom:14px;padding:12px;background:var(--surface);border-radius:var(--radius-sm);border-left:3px solid var(--primary);}
.svc-list{display:flex;flex-direction:column;gap:8px;margin-bottom:14px;}
.svc-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--surface);cursor:pointer;transition:.2s;}
.svc-item.selected{border-color:var(--primary);background:var(--primary-light);}
.svc-icon{width:38px;height:38px;border-radius:var(--radius-xs);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;}
.svc-info{flex:1;}
.svc-info b{font-size:13px;display:block;margin-bottom:2px;}
.svc-info span{font-size:11px;color:var(--text3);}
.svc-price{font-size:14px;font-weight:700;color:var(--success);}
.cta-row{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap;}
.cta-row .btn-primary,.cta-row .btn-secondary,.cta-row .btn-outline{flex:1;min-width:120px;}
.reviews-list{display:flex;flex-direction:column;gap:10px;}
.review-item{background:var(--surface);border-radius:var(--radius-sm);padding:14px;border:1px solid var(--border);}
.review-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px;}
.review-name{font-size:13px;font-weight:600;}
.review-date{font-size:11px;color:var(--text3);}
.review-stars{margin-bottom:5px;font-size:12px;}
.review-item p{font-size:12px;color:var(--text2);line-height:1.5;}

/* ===== PROVIDER DETAIL V2 ===== */
.detail-wrap{padding-bottom:24px;}

/* HERO V2 */
.provider-hero-v2{position:relative;border-radius:var(--radius);padding:18px 16px 22px;margin-bottom:16px;color:#fff;overflow:hidden;text-align:center;box-shadow:var(--shadow-md);}
.provider-hero-v2 .hero-overlay{position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(255,255,255,.18),transparent 60%),radial-gradient(circle at bottom left,rgba(0,0,0,.18),transparent 60%);pointer-events:none;}
.hero-top{position:relative;display:flex;justify-content:flex-end;gap:8px;z-index:2;}
.hero-icon-btn{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.22);backdrop-filter:blur(6px);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;transition:.2s;}
.hero-icon-btn:hover{background:rgba(255,255,255,.35);transform:scale(1.06);}
.hero-icon-btn.active{background:#fff;color:#dc2626;}
.hero-body{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:6px;margin-top:4px;}
.provider-avatar-v2{width:74px;height:74px;border-radius:50%;background:rgba(255,255,255,.22);display:flex;align-items:center;justify-content:center;font-size:30px;margin-bottom:6px;border:3px solid rgba(255,255,255,.4);box-shadow:0 4px 14px rgba(0,0,0,.2);}
.hero-name{font-size:20px;font-weight:700;line-height:1.2;}
.hero-spec{font-size:13px;opacity:.92;margin-bottom:6px;}
.hero-meta{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-top:4px;}
.hero-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:20px;background:rgba(255,255,255,.22);backdrop-filter:blur(6px);font-size:12px;font-weight:600;}
.hero-chip small{opacity:.85;font-weight:500;}
.hero-chip.chip-ok{background:rgba(22,163,74,.5);}
.hero-chip.chip-off{background:rgba(220,38,38,.5);}

/* CONTACT ACTIONS */
.contact-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px;}
.contact-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 4px;border-radius:var(--radius-sm);border:none;background:var(--surface);box-shadow:var(--shadow);cursor:pointer;transition:.2s;color:var(--text);font-family:inherit;}
.contact-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);}
.contact-btn:active{transform:scale(.97);}
.ca-icon{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;}
.ca-label{font-size:11px;font-weight:600;color:var(--text2);}
.ca-whatsapp .ca-icon{background:linear-gradient(135deg,#25D366,#128C7E);}
.ca-call .ca-icon{background:linear-gradient(135deg,#2563EB,#1d4ed8);}
.ca-chat .ca-icon{background:linear-gradient(135deg,#8b5cf6,#6d28d9);}
.ca-email .ca-icon{background:linear-gradient(135deg,#f59e0b,#d97706);}

/* QUICK STATS */
.quick-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px;}
.qstat{background:var(--surface);border-radius:var(--radius-sm);padding:10px 6px;display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center;box-shadow:var(--shadow);}
.qstat i{font-size:18px;}
.qstat b{font-size:14px;font-weight:700;color:var(--text);display:block;}
.qstat span{font-size:10px;color:var(--text3);text-transform:lowercase;}

/* SECTION TITLE WITH ACTION */
.section-title-row{display:flex;justify-content:space-between;align-items:center;margin:14px 0 8px;}
.section-title-row h3{font-size:15px;font-weight:700;display:flex;align-items:center;gap:8px;}
.section-title-row h3 i{color:var(--primary);font-size:14px;}
.link-btn{color:var(--primary);background:none;border:none;cursor:pointer;font-size:12px;font-weight:600;display:flex;align-items:center;gap:5px;font-family:inherit;}
.link-btn:hover{text-decoration:underline;}
.link-btn-muted{color:var(--text3);background:none;border:none;cursor:pointer;font-size:12px;font-weight:500;display:inline-flex;align-items:center;gap:5px;font-family:inherit;padding:8px;}
.link-btn-muted:hover{color:var(--danger);}

/* GALLERY */
.gallery-scroll{display:flex;gap:8px;overflow-x:auto;padding:2px 0 12px;margin-bottom:6px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;}
.gallery-scroll::-webkit-scrollbar{height:4px;}
.gallery-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}
.gallery-thumb{flex:0 0 140px;height:140px;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;position:relative;background:var(--surface2);scroll-snap-align:start;transition:.2s;}
.gallery-thumb:hover{transform:scale(1.02);box-shadow:var(--shadow-md);}
.gallery-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.gallery-fallback{display:none;position:absolute;inset:0;align-items:center;justify-content:center;font-size:36px;color:var(--text3);background:var(--surface2);}
.gallery-thumb.img-fallback .gallery-fallback{display:flex;}

/* GALLERY VIEWER */
.gallery-overlay{background:rgba(0,0,0,.92);align-items:center;}
.gallery-viewer{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;}
.gallery-image-wrap{max-width:90%;max-height:80vh;}
.gallery-image-wrap img{max-width:100%;max-height:80vh;border-radius:8px;display:block;}
.gallery-close{position:absolute;top:20px;right:20px;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.15);color:#fff;border:none;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;}
.gallery-close:hover{background:rgba(255,255,255,.3);}
.gallery-nav{width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.15);color:#fff;border:none;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;position:absolute;top:50%;transform:translateY(-50%);z-index:2;}
.gallery-nav:hover{background:rgba(255,255,255,.3);}
.gallery-nav[disabled]{opacity:.3;cursor:not-allowed;}
.gallery-prev{left:12px;}
.gallery-next{right:12px;}
.gallery-counter{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);color:#fff;font-size:13px;padding:6px 14px;background:rgba(0,0,0,.5);border-radius:20px;}

/* MAP ACTIONS */
.map-actions-row{display:flex;gap:8px;margin-bottom:16px;}
.map-actions-row .btn-outline{flex:1;}
.btn-sm{font-size:12px;padding:8px 12px;}

/* RATING SUMMARY V2 */
.rating-summary-v2{display:grid;grid-template-columns:120px 1fr;gap:14px;background:var(--surface);border-radius:var(--radius-sm);padding:14px;box-shadow:var(--shadow);margin-bottom:14px;align-items:center;}
.rating-summary-left{text-align:center;border-right:1px solid var(--border);padding-right:14px;}
.rating-summary-left .rating-big{font-size:36px;font-weight:800;color:var(--primary);line-height:1;margin-bottom:4px;}
.rating-summary-left .rating-stars-row{font-size:14px;color:var(--warning);margin-bottom:2px;}
.rating-summary-left .rating-count{font-size:11px;color:var(--text3);}
.rating-summary-right{display:flex;flex-direction:column;gap:5px;}
.rating-row{display:flex;align-items:center;gap:8px;font-size:11px;}
.rr-num{flex-shrink:0;width:30px;color:var(--text2);display:flex;align-items:center;gap:3px;}
.rr-num i{color:var(--warning);font-size:9px;}
.rr-bar{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden;}
.rr-fill{height:100%;background:linear-gradient(90deg,var(--warning),#fbbf24);border-radius:3px;transition:width .4s;}
.rr-pct{flex-shrink:0;width:30px;text-align:right;color:var(--text3);font-size:11px;}

/* REVIEW ITEM V2 */
.review-item{background:var(--surface);border-radius:var(--radius-sm);padding:12px 14px;border:1px solid var(--border);}
.review-header{display:flex;align-items:center;gap:10px;margin-bottom:6px;}
.review-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--info));color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.review-meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px;}
.review-name{font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px;}
.own-tag{font-size:9px;font-weight:700;color:var(--success);background:color-mix(in srgb,var(--success) 14%,transparent);padding:2px 6px;border-radius:8px;letter-spacing:.4px;}
.review-date{font-size:11px;color:var(--text3);}
.review-stars-right{font-size:12px;color:var(--warning);flex-shrink:0;}
.review-item p{font-size:12px;color:var(--text2);line-height:1.5;white-space:pre-line;}

.report-row{text-align:center;margin-top:16px;padding-top:8px;border-top:1px solid var(--border);}

/* WRITE REVIEW MODAL */
.rating-hint{text-align:center;font-size:13px;color:var(--text2);margin-bottom:14px;font-weight:500;min-height:18px;}
.review-tags-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin:0 0 14px;padding:10px;background:var(--surface2);border-radius:var(--radius-sm);}
.rt-label{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.4px;width:100%;}
.review-tag{padding:5px 10px;border-radius:14px;border:1.5px solid var(--border);background:var(--surface);font-size:11px;font-weight:600;color:var(--text2);cursor:pointer;transition:.2s;font-family:inherit;}
.review-tag:hover{border-color:var(--primary);color:var(--primary);}
.review-tag.active{background:var(--primary);color:#fff;border-color:var(--primary);}

/* SHARE MODAL */
.share-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:14px 0;}
.share-opt{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface);cursor:pointer;transition:.2s;text-decoration:none;color:var(--text2);font-family:inherit;font-size:11px;font-weight:600;}
.share-opt:hover{transform:translateY(-2px);box-shadow:var(--shadow);}
.share-opt i{font-size:22px;}
.share-opt.sh-wa i{color:#25D366;}
.share-opt.sh-fb i{color:#1877F2;}
.share-opt.sh-tg i{color:#0088cc;}
.share-opt.sh-tw i{color:var(--text);}
.share-opt.sh-mail i{color:var(--warning);}
.share-opt.sh-copy i{color:var(--primary);}

/* FAV BTN LG (legacy) */
.fav-btn-lg{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.22);color:#fff;border:none;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:.2s;}
.fav-btn-lg.active{color:#dc2626;background:#fff;}

/* Dark mode tweaks for hero */
body.dark .contact-btn{background:var(--surface);}
body.dark .qstat{background:var(--surface);}

/* Responsive */
@media (max-width:380px){
  .contact-actions{grid-template-columns:repeat(2,1fr);}
  .quick-stats-grid{grid-template-columns:repeat(2,1fr);}
  .share-grid{grid-template-columns:repeat(2,1fr);}
  .rating-summary-v2{grid-template-columns:1fr;}
  .rating-summary-left{border-right:none;border-bottom:1px solid var(--border);padding-right:0;padding-bottom:10px;}
}

/* Event admin log */
.event-list{display:flex;flex-direction:column;gap:8px;}
.event-card{background:var(--surface);border-radius:var(--radius-sm);padding:10px 12px;border:1px solid var(--border);box-shadow:var(--shadow);}
.event-header{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:13px;}
.event-header b{flex:1;font-weight:700;}
.event-time{font-size:10px;color:var(--text3);}
.event-body{font-size:12px;color:var(--text2);line-height:1.5;display:flex;flex-direction:column;gap:2px;padding-left:24px;}
.event-body b{color:var(--text);text-transform:capitalize;}

/* ===== BANNERS HOME (Garantía + Referidos) ===== */
.guarantee-banner{display:flex;align-items:center;gap:12px;padding:12px 14px;background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;border-radius:var(--radius);margin-bottom:12px;cursor:pointer;box-shadow:0 4px 14px rgba(22,163,74,.25);transition:.2s;}
.guarantee-banner:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(22,163,74,.35);}
.gb-icon{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.22);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.gb-text{flex:1;}
.gb-text b{display:block;font-size:14px;font-weight:700;}
.gb-text span{display:block;font-size:11px;opacity:.92;line-height:1.4;}
.gb-arrow{font-size:14px;opacity:.7;}

.referral-cta{display:flex;align-items:center;gap:12px;padding:12px 14px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border-radius:var(--radius);margin-bottom:14px;cursor:pointer;box-shadow:0 4px 14px rgba(245,158,11,.25);transition:.2s;}
.referral-cta:hover{transform:translateY(-2px);}
.rcta-icon{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.22);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;}
.rcta-text b{display:block;font-size:13px;}
.rcta-text span{display:block;font-size:11px;opacity:.92;}

/* ===== PRO BANNER ===== */
.pro-cta-banner{display:flex;align-items:center;gap:12px;padding:14px 16px;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;border-radius:var(--radius);margin-bottom:14px;cursor:pointer;box-shadow:0 6px 24px rgba(245,158,11,.3);transition:.2s;}
.pro-cta-banner:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(245,158,11,.45);}
.pcb-icon{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.28);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.pcb-text{flex:1;}
.pcb-text b{display:block;font-size:14px;font-weight:700;}
.pcb-text span{display:block;font-size:11px;opacity:.95;line-height:1.4;}
.pro-active-strip{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;margin-bottom:14px;display:flex;align-items:center;gap:8px;}

/* PRO Modal */
.pro-badge{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;padding:6px 16px;border-radius:20px;font-size:12px;font-weight:700;margin-bottom:14px;}
.pro-benefits{display:flex;flex-direction:column;gap:8px;text-align:left;margin:14px 0;background:var(--surface2);padding:14px;border-radius:var(--radius-sm);}
.pro-benefit{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text2);}
.pro-benefit i{color:#f59e0b;width:18px;text-align:center;}
.pro-plans{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:14px 0;}
.pro-plan{position:relative;padding:14px 8px;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--surface);cursor:pointer;transition:.2s;}
.pro-plan:hover,.pro-plan.selected{border-color:#f59e0b;background:rgba(245,158,11,.05);}
.pp-name{font-size:12px;font-weight:600;color:var(--text3);text-transform:uppercase;}
.pp-price{font-size:24px;font-weight:800;color:var(--primary);margin-top:4px;}
.pp-price small{font-size:11px;font-weight:500;color:var(--text3);}
.pp-badge{position:absolute;top:-8px;right:8px;background:var(--success);color:#fff;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:700;}
.pro-active-banner{background:rgba(22,163,74,.1);color:var(--success);padding:12px;border-radius:var(--radius-sm);margin:14px 0;text-align:center;font-weight:600;font-size:13px;line-height:1.5;}

/* ===== Pay Breakdown ===== */
.pay-breakdown{background:var(--surface2);border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:12px;}
.pb-row{display:flex;justify-content:space-between;font-size:13px;color:var(--text2);padding:3px 0;}
.pb-total{padding-top:8px;margin-top:4px;border-top:1px dashed var(--border);font-weight:700;color:var(--text);font-size:15px;}
.pb-guarantee{margin-top:10px;padding:10px;background:rgba(22,163,74,.1);border-radius:var(--radius-xs);color:var(--success);font-size:12px;display:flex;gap:10px;align-items:center;cursor:pointer;border-left:3px solid var(--success);transition:.2s;}
.pb-guarantee:hover{background:rgba(22,163,74,.18);}
.pb-guarantee i{font-size:18px;flex-shrink:0;}
.pb-guarantee span{line-height:1.4;}

/* ===== Legal Modal ===== */
.legal-sheet{max-width:600px;margin:0 auto;padding:0;display:flex;flex-direction:column;max-height:90dvh;}
.legal-sheet .modal-header{position:sticky;top:0;background:var(--surface);z-index:2;}
.legal-body{padding:16px 18px 22px;overflow-y:auto;font-size:13px;line-height:1.6;color:var(--text2);}
.legal-body h4{font-size:15px;font-weight:700;color:var(--text);margin:14px 0 8px;}
.legal-body h4:first-child{margin-top:0;}
.legal-body p{margin-bottom:10px;}
.legal-body ul,.legal-body ol{padding-left:22px;margin-bottom:10px;}
.legal-body li{margin-bottom:4px;}
.legal-body a{color:var(--primary);font-weight:600;}
.legal-body i{color:var(--text3);}

/* Consent rows en registro */
.legal-consent{display:flex;flex-direction:column;gap:8px;margin:14px 0 12px;padding:10px 12px;background:var(--surface2);border-radius:var(--radius-sm);}
.consent-row{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:var(--text2);line-height:1.5;cursor:pointer;}
.consent-row input{margin-top:2px;flex-shrink:0;}
.consent-row a{color:var(--primary);font-weight:600;}
.login-legal-note{font-size:11px;color:var(--text3);text-align:center;margin-top:10px;line-height:1.5;}
.login-legal-note a{color:var(--primary);}

/* ===== Referral Modal ===== */
.referral-code-box{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 14px;background:linear-gradient(135deg,#16a34a08,#16a34a02);border:2px dashed var(--success);border-radius:var(--radius);margin:14px 0;}
.rc-label{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--text3);letter-spacing:.5px;}
.rc-code{font-family:'Courier New',monospace;font-size:28px;font-weight:800;color:var(--success);letter-spacing:3px;}
.referral-link-row{display:flex;gap:6px;}
.referral-link-row input{flex:1;font-size:12px;}
.referral-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:14px 0;}
.rs-item{background:var(--surface2);padding:12px;border-radius:var(--radius-sm);text-align:center;}
.rs-item b{display:block;font-size:22px;font-weight:800;color:var(--primary);}
.rs-item span{font-size:11px;color:var(--text3);}

/* ===== NPS ===== */
.nps-scale{display:grid;grid-template-columns:repeat(11,1fr);gap:4px;margin:14px 0 4px;}
.nps-num{width:100%;aspect-ratio:1;border-radius:50%;border:2px solid var(--border);background:var(--surface);font-weight:700;font-size:12px;cursor:pointer;transition:.18s;color:var(--text2);font-family:inherit;}
.nps-num:hover{border-color:var(--primary);}
.nps-num.selected{transform:scale(1.15);color:#fff;border-color:transparent;}
.nps-num.nps-detractor.selected{background:var(--danger);}
.nps-num.nps-passive.selected{background:var(--warning);}
.nps-num.nps-promoter.selected{background:var(--success);}
.nps-labels{display:flex;justify-content:space-between;font-size:10px;color:var(--text3);margin-bottom:10px;}

/* ===== Footer Legal ===== */
.legal-footer{margin-top:32px;padding:20px 16px 16px;border-top:1px solid var(--border);background:var(--surface2);border-radius:var(--radius) var(--radius) 0 0;}
.lf-brand{margin-bottom:14px;}
.lf-logo{font-size:18px;font-weight:800;color:var(--primary);font-family:'Syne',sans-serif;display:flex;align-items:center;gap:6px;}
.lf-brand p{font-size:12px;color:var(--text3);line-height:1.6;margin-top:6px;}
.lf-company{font-size:11px !important;color:var(--text3) !important;}
.lf-company a{color:var(--primary);}
.lf-links{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;border-top:1px solid var(--border);padding-top:14px;}
.lf-links a{font-size:12px;color:var(--text2);display:flex;align-items:center;gap:6px;}
.lf-links a:hover{color:var(--primary);text-decoration:underline;}
.lf-links a::before{content:'›';color:var(--primary);font-weight:bold;}
.lf-foot{border-top:1px solid var(--border);padding-top:10px;text-align:center;}
.lf-foot small{font-size:10px;color:var(--text3);}

/* Recording overlay para video KYC */
.kyc-recording-overlay{position:absolute;top:12px;left:12px;display:flex;align-items:center;gap:6px;background:rgba(220,38,38,.92);color:#fff;padding:5px 10px;border-radius:14px;font-size:13px;font-weight:700;}
.kyc-rec-dot{width:8px;height:8px;border-radius:50%;background:#fff;animation:recPulse 1s infinite;}
@keyframes recPulse{50%{opacity:.3;}}
.kyc-review-photo video{width:100%;aspect-ratio:1;border-radius:var(--radius-sm);border:2px solid var(--border);background:#000;}

/* ===== KYC / VERIFICACIÓN ===== */
.kyc-sheet{max-width:520px;margin:0 auto;padding:0 0 16px;display:flex;flex-direction:column;}
.kyc-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:2;}
.kyc-header h3{font-size:16px;font-weight:700;display:flex;align-items:center;gap:8px;}
.kyc-header h3 i{color:var(--primary);}
.kyc-steps{display:flex;gap:4px;padding:14px 16px 8px;border-bottom:1px solid var(--border);overflow-x:auto;background:var(--surface2);}
.kyc-step{flex:1;min-width:62px;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;color:var(--text3);position:relative;}
.kyc-step span{width:26px;height:26px;border-radius:50%;background:var(--border);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;transition:.2s;}
.kyc-step b{font-size:10px;font-weight:600;text-align:center;}
.kyc-step.active span{background:var(--primary);transform:scale(1.1);box-shadow:0 0 0 4px var(--primary-light);}
.kyc-step.active b{color:var(--primary);}
.kyc-step.done span{background:var(--success);}
.kyc-step.done span::before{content:'✓';font-size:14px;}
.kyc-step.done span{font-size:0;}
.kyc-body{padding:16px;flex:1;overflow-y:auto;}
.kyc-content{display:flex;flex-direction:column;gap:14px;}
.kyc-instructions{text-align:center;padding:8px 0;}
.kyc-emoji{font-size:42px;margin-bottom:6px;}
.kyc-instructions h4{font-size:17px;font-weight:700;margin-bottom:6px;}
.kyc-instructions p{font-size:13px;color:var(--text2);line-height:1.5;}

.kyc-camera-wrap{position:relative;width:100%;aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;background:#000;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);}
.kyc-camera-wrap video{width:100%;height:100%;object-fit:cover;}
.kyc-preview-img{width:100%;height:100%;object-fit:cover;}
.kyc-guide{position:absolute;inset:0;pointer-events:none;display:flex;align-items:center;justify-content:center;}
.kyc-guide::after{content:'';display:block;border:3px dashed rgba(255,255,255,.85);box-shadow:0 0 0 9999px rgba(0,0,0,.35);}
.kyc-guide-circle::after{width:62%;aspect-ratio:1;border-radius:50%;}
.kyc-guide-rect::after{width:88%;aspect-ratio:1.586;border-radius:14px;}
.kyc-camera-error{padding:18px;text-align:center;color:var(--text2);background:var(--surface2);border-radius:var(--radius-sm);margin-top:10px;}
.kyc-camera-error i{font-size:32px;color:var(--danger);margin-bottom:8px;display:block;}
.kyc-camera-error p{font-size:13px;line-height:1.5;}

.kyc-actions{display:flex;gap:8px;}
.kyc-actions .btn-primary,.kyc-actions .btn-outline,.kyc-actions .btn-secondary{flex:1;justify-content:center;}
.kyc-back-btn{background:none;border:none;color:var(--text3);font-size:12px;cursor:pointer;padding:8px;text-align:center;display:flex;align-items:center;justify-content:center;gap:5px;font-family:inherit;}
.kyc-back-btn:hover{color:var(--primary);}

.kyc-form{display:flex;flex-direction:column;gap:10px;}

.kyc-review{display:flex;flex-direction:column;gap:14px;}
.kyc-review-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.kyc-review-photo{display:flex;flex-direction:column;gap:4px;text-align:center;}
.kyc-review-photo img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:var(--radius-sm);border:2px solid var(--border);}
.kyc-review-photo span{font-size:10px;color:var(--text3);font-weight:600;}
.kyc-review-data{background:var(--surface2);border-radius:var(--radius-sm);padding:12px;display:flex;flex-direction:column;gap:5px;}
.krd-row{font-size:13px;color:var(--text2);}
.krd-row b{color:var(--text);}
.krd-row code{background:var(--bg);padding:1px 6px;border-radius:4px;font-size:11px;}
.kyc-consent{padding:10px;background:var(--primary-light);border-radius:var(--radius-sm);border-left:3px solid var(--primary);}
.kyc-consent label{display:flex;gap:8px;font-size:12px;color:var(--text2);line-height:1.5;cursor:pointer;align-items:flex-start;}
.kyc-consent input{margin-top:2px;flex-shrink:0;}

/* Badges de verificación */
.verif-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:14px;font-size:11px;font-weight:700;}
.verif-ok{background:rgba(22,163,74,.18);color:#16a34a;}
.verif-pending{background:rgba(245,158,11,.18);color:#d97706;}
.verif-no{background:rgba(220,38,38,.18);color:#dc2626;}
.verif-none{background:rgba(100,116,139,.18);color:#64748b;}

/* Tarjeta de estado en perfil */
.verif-card{background:var(--surface);border-radius:var(--radius);padding:14px;margin-bottom:14px;box-shadow:var(--shadow);border-left:4px solid var(--success);}
.verif-card-warn{border-left-color:var(--warning);}
.verif-card-header{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;margin-bottom:8px;}
.verif-card-header i{color:var(--primary);}
.verif-card-body{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text2);}
.verif-card-body p{font-size:13px;color:var(--text2);margin-bottom:8px;line-height:1.5;}

/* Panel admin de KYC */
.kyc-admin-list{display:flex;flex-direction:column;gap:14px;margin-top:14px;}
.kyc-admin-card{background:var(--surface);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow);border:1px solid var(--border);}
.kyc-admin-header{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:12px;}
.kyc-admin-header h4{font-size:15px;font-weight:700;margin-bottom:2px;}
.kyc-admin-header small{font-size:11px;color:var(--text3);}
.kyc-admin-header code{background:var(--bg);padding:1px 6px;border-radius:4px;font-size:10px;}
.kyc-admin-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px;}
.kap-thumb{position:relative;cursor:pointer;border-radius:var(--radius-sm);overflow:hidden;border:2px solid var(--border);transition:.2s;}
.kap-thumb:hover{transform:scale(1.02);border-color:var(--primary);}
.kap-thumb img{width:100%;aspect-ratio:1;object-fit:cover;display:block;}
.kap-thumb span{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.65);color:#fff;font-size:10px;font-weight:600;padding:4px 6px;text-align:center;}
.kyc-admin-data{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text2);background:var(--surface2);border-radius:var(--radius-sm);padding:10px;margin-bottom:10px;}
.kyc-admin-data b{color:var(--text);margin-right:4px;}
.kyc-admin-actions{display:flex;gap:8px;}
.kyc-admin-actions button{flex:1;}
.kyc-admin-reason{padding:8px 10px;background:rgba(220,38,38,.1);border-left:3px solid var(--danger);border-radius:var(--radius-xs);font-size:12px;color:var(--danger);}

.gallery-download{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);background:#fff;color:#2563EB;padding:10px 20px;border-radius:24px;font-size:13px;font-weight:700;text-decoration:none;display:flex;align-items:center;gap:6px;box-shadow:0 4px 14px rgba(0,0,0,.3);}
.gallery-download:hover{background:#f0f4f8;}

/* Responsive KYC */
@media (max-width:480px){
  .kyc-step b{display:none;}
  .kyc-steps{padding:14px 8px 8px;}
}

/* Cart */
.cart-list{display:flex;flex-direction:column;gap:10px;margin-bottom:14px;}
.cart-item{display:flex;gap:12px;background:var(--surface);border-radius:var(--radius-sm);padding:12px;box-shadow:var(--shadow);}
.cart-item-img{width:52px;height:52px;border-radius:var(--radius-xs);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;}
.cart-item-info{flex:1;min-width:0;}
.cart-item-info h4{font-size:13px;font-weight:600;margin-bottom:2px;}
.cart-item-info span{font-size:11px;color:var(--text3);display:block;margin-bottom:6px;}
.qty-controls{display:inline-flex;align-items:center;gap:8px;background:var(--surface2);border-radius:var(--radius-xs);padding:4px 8px;}
.qty-controls button{width:22px;height:22px;border-radius:4px;background:var(--border);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--text);}
.qty-controls span{font-size:13px;font-weight:700;min-width:20px;text-align:center;}
.cart-item-right{display:flex;flex-direction:column;align-items:flex-end;justify-content:space-between;}
.cart-item-price{font-size:14px;font-weight:700;color:var(--primary);}
.cart-remove{color:var(--danger);font-size:14px;background:none;border:none;cursor:pointer;}
.cart-summary{background:var(--surface);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-md);}
.summary-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:13px;color:var(--text2);}
.total-row{font-size:16px;font-weight:700;color:var(--text);border-top:2px solid var(--border);margin-top:4px;padding-top:10px!important;}
.total-row span{font-size:18px;}

/* Orders */
.orders-list{display:flex;flex-direction:column;gap:10px;}
.order-card{background:var(--surface);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow);}
.order-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;}
.order-id{font-size:13px;font-weight:700;color:var(--primary);margin-right:8px;}
.order-body{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px;}
.order-info{display:flex;align-items:center;gap:10px;flex:1;}
.order-info i{font-size:20px;flex-shrink:0;}
.order-info b{font-size:13px;font-weight:600;display:block;}
.order-info span{font-size:11px;color:var(--text3);}
.order-total{font-size:15px;font-weight:700;color:var(--success);flex-shrink:0;}
.order-date{font-size:11px;color:var(--text3);}
.order-footer{display:flex;align-items:center;justify-content:space-between;padding-top:8px;border-top:1px solid var(--border);}
.pay-method{font-size:11px;color:var(--text3);display:flex;align-items:center;gap:5px;}

/* Tracking */
.tracking-card{background:var(--surface);border-radius:var(--radius-sm);padding:14px;box-shadow:var(--shadow);margin-bottom:10px;}
.tracking-order-info{display:flex;align-items:center;gap:8px;margin-bottom:6px;}
.track-provider{font-size:12px;color:var(--text3);display:flex;align-items:center;gap:6px;margin-top:4px;}
.tracking-steps{display:flex;justify-content:space-between;align-items:flex-start;margin-top:16px;position:relative;}
.tracking-steps::before{content:'';position:absolute;top:14px;left:10%;right:10%;height:2px;background:var(--border);}
.track-step{text-align:center;flex:1;position:relative;z-index:1;}
.track-step i{font-size:22px;display:block;margin-bottom:5px;color:var(--border);}
.track-step span{font-size:10px;color:var(--text3);display:block;}
.track-step.done i,.track-step.done span{color:var(--success);}
.track-step.active i,.track-step.active span{color:var(--primary);}
.info-banner{background:var(--primary-light);color:var(--primary);border-radius:var(--radius-sm);padding:10px 14px;font-size:12px;display:flex;align-items:center;gap:8px;margin-bottom:10px;}

/* Profile / Settings */
.profile-hero{display:flex;align-items:center;gap:16px;padding:18px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:var(--radius);color:#fff;margin-bottom:16px;}
.profile-avatar-lg{width:60px;height:60px;border-radius:50%;background:rgba(255,255,255,.25);font-size:26px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.profile-info h2{font-size:17px;font-weight:700;margin-bottom:4px;}
.profile-info p{font-size:12px;opacity:.8;margin-top:4px;}
.settings-group{background:var(--surface);border-radius:var(--radius);padding:4px 14px;box-shadow:var(--shadow);margin-bottom:12px;}
.settings-group-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);padding:10px 0 6px;}
.settings-item{display:flex;align-items:center;gap:12px;padding:13px 0;border-bottom:1px solid var(--border);cursor:pointer;}
.settings-item:last-child{border:none;}
.settings-item>i:first-child{font-size:17px;color:var(--primary);width:20px;text-align:center;flex-shrink:0;}
.settings-item>span{flex:1;font-size:14px;}
.settings-item.danger>i,.settings-item.danger>span{color:var(--danger);}
.settings-item>i:last-child{color:var(--text3);font-size:12px;}

/* Toggle (HTML label version) */
.toggle{display:inline-flex;cursor:pointer;}
.toggle input{display:none;}
.toggle-slider{width:44px;height:24px;border-radius:12px;background:var(--border);position:relative;transition:.25s;}
.toggle input:checked+.toggle-slider{background:var(--primary);}
.toggle-slider::after{content:'';position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.25s;box-shadow:0 1px 4px rgba(0,0,0,.2);}
.toggle input:checked+.toggle-slider::after{left:23px;}

/* Accordion v3 */
.accordion{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);margin-bottom:6px;}
.accordion-item{border-bottom:1px solid var(--border);}
.accordion-item:last-child{border:none;}
.accordion-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;cursor:pointer;font-size:14px;font-weight:500;background:var(--surface);color:var(--text);transition:.18s;}
.accordion-header:hover{background:var(--surface2);}
.accordion-header i{font-size:11px;color:var(--text3);transition:transform .3s;}
.accordion-item.open .accordion-header{color:var(--primary);}
.accordion-item.open .accordion-header i{transform:rotate(180deg);}
.accordion-body{max-height:0;overflow:hidden;transition:max-height .4s ease;padding:0 16px;}
.accordion-item.open .accordion-body{max-height:2000px;padding:0 16px 16px;}

/* Support */
.support-contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px;}
.support-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;background:var(--surface);border-radius:var(--radius-sm);box-shadow:var(--shadow);font-size:12px;font-weight:600;color:var(--primary);border:none;cursor:pointer;text-decoration:none;transition:.2s;}
.support-card i{font-size:22px;}
.support-card:hover{background:var(--primary);color:#fff;}

/* Payment Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:8000;display:none;align-items:flex-end;animation:fadeIn .2s;}
.modal-overlay.open{display:flex;}
.modal-sheet{background:var(--surface);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-height:93dvh;overflow-y:auto;animation:slideUp .28s ease;padding:4px 16px 24px;}
.modal-sheet.modal-center{border-radius:var(--radius);max-width:460px;margin:auto;padding:24px;text-align:center;}
.modal-sheet.modal-tall{max-height:90dvh;display:flex;flex-direction:column;padding:0;}
.modal-handle{width:40px;height:4px;border-radius:2px;background:var(--border);margin:10px auto 4px;}
.modal-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);}
.modal-header h3{font-size:16px;font-weight:700;display:flex;align-items:center;gap:8px;}
.modal-close{width:32px;height:32px;border-radius:50%;background:var(--surface2);border:none;cursor:pointer;font-size:14px;color:var(--text3);display:flex;align-items:center;justify-content:center;}
body.modal-open{overflow:hidden;}
.pay-summary{background:var(--primary-light);border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;}
.pay-description{font-size:13px;color:var(--text2);}
.pay-amount{font-size:18px;font-weight:700;color:var(--primary);}
.step-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--text3);margin-bottom:10px;}
.bank-list{display:flex;flex-direction:column;gap:8px;margin-bottom:14px;}
.bank-chip{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--surface);cursor:pointer;font-size:13px;font-weight:600;transition:.2s;width:100%;}
.bank-chip.selected{border-color:var(--bank-c,var(--primary));background:color-mix(in srgb,var(--bank-c,var(--primary)) 8%,white);}
.bank-chip i{color:var(--bank-c,var(--primary));font-size:18px;}
.pay-divider{display:flex;align-items:center;gap:10px;margin:12px 0;color:var(--text3);font-size:12px;}
.pay-divider::before,.pay-divider::after{content:'';flex:1;height:1px;background:var(--border);}
.cash-btn{width:100%;}
.card-preview{background:linear-gradient(135deg,#2563EB,#1e3a8a);border-radius:16px;padding:20px 22px;color:#fff;margin:0 auto 16px;max-width:320px;min-height:160px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:var(--shadow-lg);transition:background .3s;}
.card-preview-brand{font-size:18px;opacity:.8;}
.card-preview-number{font-family:'Courier New',monospace;font-size:17px;letter-spacing:3px;margin:10px 0;opacity:.95;}
.card-preview-bottom{display:flex;justify-content:space-between;align-items:flex-end;}
.card-preview-name{font-size:12px;letter-spacing:1px;opacity:.85;}
.card-preview-exp{font-size:12px;opacity:.7;}

/* Chat Modal */
.modal-sheet.modal-tall .modal-header{padding:12px 16px;flex-shrink:0;}
.chat-header-info{display:flex;align-items:center;gap:10px;}
.chat-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary-light);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;}
.chat-header-info h4{font-size:14px;font-weight:700;}
.chat-status{font-size:11px;color:var(--success);}
.chat-messages{flex:1;overflow-y:auto;padding:14px;background:var(--surface2);display:flex;flex-direction:column;gap:10px;}
.chat-msg{display:flex;flex-direction:column;}
.chat-msg.user{align-items:flex-end;}
.chat-msg.provider{align-items:flex-start;}
.chat-bubble{max-width:80%;padding:10px 14px;border-radius:14px;font-size:13px;line-height:1.45;}
.chat-msg.user .chat-bubble{background:var(--primary);color:#fff;border-bottom-right-radius:3px;}
.chat-msg.provider .chat-bubble{background:var(--surface);border:1px solid var(--border);border-bottom-left-radius:3px;}
.chat-time{font-size:10px;color:var(--text3);margin-top:3px;}
.chat-input-bar{display:flex;gap:8px;padding:10px 14px;border-top:1px solid var(--border);flex-shrink:0;background:var(--surface);}
.chat-input{flex:1;padding:10px 14px;border:2px solid var(--border);border-radius:25px;font-size:13px;background:var(--surface);color:var(--text);outline:none;transition:.2s;}
.chat-input:focus{border-color:var(--primary);}
.chat-send-btn{width:40px;height:40px;border-radius:50%;background:var(--primary);color:#fff;font-size:15px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;}

/* Rating */
.rating-stars-input{display:flex;justify-content:center;gap:8px;margin:16px 0;}
.rating-star{background:none;border:none;cursor:pointer;font-size:36px;color:var(--border);transition:.2s;}
.rating-star.active{color:var(--warning);}
.rating-summary{text-align:center;padding:16px;background:var(--surface);border-radius:var(--radius-sm);margin-bottom:14px;}
.rating-big{font-size:48px;font-weight:800;color:var(--primary);}
.rating-stars-row{font-size:20px;margin:4px 0;}
.rating-count{font-size:12px;color:var(--text3);}

/* Success Modal */
.success-icon{font-size:64px;color:var(--success);display:block;margin:0 auto 16px;}
.modal-sheet.modal-center h3{font-size:20px;font-weight:700;margin-bottom:8px;}
.modal-sheet.modal-center p{font-size:13px;color:var(--text2);margin-bottom:18px;line-height:1.5;}

/* Toast v3 */
.toast{position:fixed;bottom:calc(var(--bnav-h) + 14px);left:50%;transform:translateX(-50%) translateY(20px);background:#0f172a;color:#fff;padding:11px 20px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;z-index:9999;opacity:0;transition:opacity .3s,transform .3s;pointer-events:none;display:flex;align-items:center;gap:8px;max-width:90%;white-space:nowrap;box-shadow:0 4px 16px rgba(0,0,0,.3);}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.toast-success{background:var(--success);}
.toast-error{background:var(--danger);}
.toast-warning{background:var(--warning);color:#1c1c1c;}

/* Data Table v3 */
.data-table{width:100%;border-collapse:collapse;font-size:13px;background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);}
.data-table th{background:var(--surface2);padding:11px 14px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--text3);border-bottom:2px solid var(--border);}
.data-table td{padding:10px 14px;border-bottom:1px solid var(--border);vertical-align:middle;}
.data-table tr:last-child td{border:none;}
.data-table tr:hover td{background:var(--primary-light);}

/* Provider Dashboard */
.prov-hero{display:flex;align-items:center;gap:14px;padding:16px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:var(--radius);color:#fff;margin-bottom:14px;}
.prov-hero .prov-avatar{width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.25);font-size:22px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.stat-card{background:var(--surface);border-radius:var(--radius-sm);padding:14px;box-shadow:var(--shadow);display:flex;align-items:center;gap:12px;}
.stat-card i{font-size:26px;flex-shrink:0;}
.stat-num{font-size:20px;font-weight:800;display:block;}
.stat-label{font-size:11px;color:var(--text3);}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:14px;}

/* Requests */
.requests-list{display:flex;flex-direction:column;gap:10px;}
.request-card{background:var(--surface);border-radius:var(--radius-sm);padding:14px;box-shadow:var(--shadow);border-left:3px solid var(--primary);}
.request-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.request-body{display:flex;align-items:center;gap:10px;}
.request-body i{font-size:20px;color:var(--text3);flex-shrink:0;}
.request-body>div{flex:1;}
.request-body b{font-size:13px;font-weight:600;display:block;}
.request-body span{font-size:11px;color:var(--text3);}
.request-date{display:block;font-size:11px;color:var(--text3);}
.request-price{font-size:15px;font-weight:700;color:var(--success);flex-shrink:0;}
.request-actions{display:flex;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border);}

/* Charts */
.chart-bar-container{display:flex;align-items:flex-end;gap:6px;height:120px;background:var(--surface);border-radius:var(--radius-sm);padding:12px 12px 4px;margin-bottom:6px;}
.chart-bar-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%;}
.chart-bar{width:100%;border-radius:4px 4px 0 0;min-height:4px;transition:.4s;}
.chart-bar-item span{font-size:9px;color:var(--text3);flex-shrink:0;}

/* System Status */
.system-status-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:12px;}
.status-item{display:flex;align-items:center;gap:8px;font-size:13px;padding:8px 12px;background:var(--surface);border-radius:var(--radius-xs);border:1px solid var(--border);}
.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.status-dot.green{background:var(--success);}
.status-dot.yellow{background:var(--warning);}
.status-dot.red{background:var(--danger);}

/* Cat Stats */
.cat-stats-list{display:flex;flex-direction:column;gap:8px;margin-bottom:14px;}
.cat-stat-item{display:flex;align-items:center;gap:10px;font-size:13px;}
.cat-stat-item i{font-size:16px;width:20px;text-align:center;flex-shrink:0;}
.cat-stat-item>span:nth-child(2){flex:1;}
.stat-bar{flex:2;height:8px;background:var(--border);border-radius:4px;overflow:hidden;}
.stat-bar div{height:100%;border-radius:4px;transition:.4s;}
.cat-stat-item>span:last-child{font-size:11px;color:var(--text3);width:50px;text-align:right;}

/* Misc */
.empty-state{text-align:center;padding:40px 20px;}
.empty-state i{font-size:48px;color:var(--border);display:block;margin-bottom:12px;}
.empty-state h3{font-size:16px;font-weight:600;margin-bottom:6px;}
.empty-state p{font-size:13px;color:var(--text3);margin-bottom:14px;}
.empty-state-sm{text-align:center;padding:20px;color:var(--text3);}
.empty-state-sm i{font-size:32px;margin-bottom:8px;display:block;}
.empty-note{text-align:center;color:var(--text3);font-size:13px;padding:20px;}
.search-bar-simple{display:flex;align-items:center;gap:8px;background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;margin-bottom:12px;}
.search-bar-simple i{color:var(--text3);}
.search-bar-simple input{border:none;background:none;color:var(--text);font-size:14px;outline:none;flex:1;}
.addresses-list{display:flex;flex-direction:column;gap:8px;margin-bottom:14px;}
.address-card{display:flex;align-items:flex-start;gap:10px;padding:12px;background:var(--surface);border-radius:var(--radius-sm);border:2px solid var(--border);}
.address-card.default{border-color:var(--primary);}
.address-card i{color:var(--primary);font-size:18px;flex-shrink:0;margin-top:2px;}
.address-card>div{flex:1;}
.address-card b{font-size:13px;font-weight:600;}
.address-card p{font-size:12px;color:var(--text2);}
.address-card button{color:var(--danger);border:none;background:none;cursor:pointer;font-size:16px;flex-shrink:0;}
.saved-cards{display:flex;flex-direction:column;gap:8px;margin-bottom:14px;}
.saved-card-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--surface);border-radius:var(--radius-sm);border:1px solid var(--border);}
.saved-card-item i{font-size:20px;color:var(--primary);}
.saved-card-item>div{flex:1;}
.saved-card-item b{font-size:13px;display:block;}
.saved-card-item p{font-size:12px;color:var(--text3);}
.saved-card-item button{color:var(--danger);border:none;background:none;cursor:pointer;font-size:16px;}
.quote-prov-name{color:var(--primary);}
.admin-part{position:relative;}
.admin-actions{display:flex;gap:6px;margin-top:8px;}

/* Quote + Rating modal */
.modal-sheet h3{font-size:17px;font-weight:700;margin-bottom:8px;}
.modal-sheet>p{font-size:13px;color:var(--text2);margin-bottom:14px;}

/* === MAP LOCATE BUTTON & USER DOT === */
.map-locate-btn{
  width:36px;height:36px;border-radius:8px;
  background:#fff;border:2px solid rgba(0,0,0,.2);
  display:flex;align-items:center;justify-content:center;
  font-size:15px;color:#555;cursor:pointer;
  box-shadow:0 2px 6px rgba(0,0,0,.2);
  transition:.2s;margin-bottom:4px;
}
.map-locate-btn:hover{background:var(--primary-light);color:var(--primary);}
.map-locate-btn.locating{color:var(--primary);}
body.dark .map-locate-btn{background:#1e293b;border-color:#475569;color:#cbd5e1;}
body.dark .map-locate-btn:hover{background:#2563EB;color:#fff;}

/* User location marker */
.user-location-dot{
  width:20px;height:20px;position:relative;
  display:flex;align-items:center;justify-content:center;
}
.user-location-dot::after{
  content:'';width:14px;height:14px;border-radius:50%;
  background:#2563EB;border:3px solid #fff;
  box-shadow:0 0 0 2px #2563EB;
  position:absolute;z-index:2;
}
.user-location-pulse{
  position:absolute;width:40px;height:40px;border-radius:50%;
  background:rgba(37,99,235,.25);
  animation:locatePulse 1.8s ease-out infinite;
  transform:translate(-50%,-50%);left:50%;top:50%;
}
@keyframes locatePulse{
  0%{transform:translate(-50%,-50%) scale(.4);opacity:1;}
  100%{transform:translate(-50%,-50%) scale(2.2);opacity:0;}
}

/* Leaflet layer control dark mode */
body.dark .leaflet-control-layers{background:#1e293b;border-color:#334155;color:#f1f5f9;}
body.dark .leaflet-control-layers-toggle{background-color:#1e293b;}
body.dark .leaflet-control-layers label{color:#f1f5f9;}
body.dark .leaflet-bar a{background:#1e293b;color:#f1f5f9;border-bottom-color:#334155;}
body.dark .leaflet-bar a:hover{background:#2563EB;color:#fff;}

/* ===== SOCIAL AUTH BUTTONS ===== */
/* ===== TOPNAV BACK + HOME ===== */
.nav-left{display:flex;align-items:center;gap:4px;}
.nav-brand{display:flex;align-items:center;gap:8px;font-family:'Syne',sans-serif;font-size:20px;font-weight:800;color:var(--primary);background:none;border:none;cursor:pointer;padding:4px 6px;border-radius:8px;transition:.2s;}
.nav-brand:hover{background:var(--primary-light);}
.nav-back-btn{width:36px;height:36px;border-radius:50%;background:var(--surface);border:1.5px solid var(--border);color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:.2s;flex-shrink:0;}
.nav-back-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary);}

/* ===== SOCIAL AUTH BUTTONS ===== */
.social-divider{display:flex;align-items:center;gap:10px;margin:18px 0 14px;color:var(--text3);font-size:12px;}
.social-divider::before,.social-divider::after{content:'';flex:1;height:1px;background:var(--border);}
.social-btns{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:4px;}
.social-btn{display:flex;flex-direction:column;align-items:center;gap:5px;padding:10px 6px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface);cursor:pointer;transition:.2s;font-size:11px;font-weight:600;color:var(--text2);font-family:inherit;}
.social-btn i{font-size:18px;}
.social-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow);}
.social-btn.google i{color:#DB4437;}
.social-btn.google:hover{border-color:#DB4437;background:#DB443710;}
.social-btn.facebook i{color:#1877F2;}
.social-btn.facebook:hover{border-color:#1877F2;background:#1877F210;}
.social-btn.apple i{color:var(--text);}
.social-btn.apple:hover{border-color:var(--text);background:var(--bg);}
.social-btn.phone i{color:#16a34a;}
.social-btn.phone:hover{border-color:#16a34a;background:#16a34a10;}
body.dark .social-btn{background:#1e293b;border-color:#334155;}

/* Phone auth input row */
.phone-input-row{display:grid;grid-template-columns:90px 1fr;gap:8px;}
.phone-code{padding-right:4px;}

/* OTP input boxes */
.otp-input-row{display:flex;gap:8px;justify-content:center;margin:16px 0;}
.otp-box{width:44px;height:52px;text-align:center;font-size:22px;font-weight:700;font-family:var(--font-main);border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);caret-color:var(--primary);outline:none;transition:.15s;}
.otp-box:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.15);}
.otp-hint{text-align:center;font-size:12px;color:var(--text2);margin-bottom:4px;}
.otp-phone-display{text-align:center;font-weight:600;color:var(--text);margin-bottom:4px;}

/* ===== MAP SECTION — container, popup, results list ===== */
.section-map-container{height:420px;border-radius:var(--radius);overflow:hidden;margin-bottom:0;}

/* Leaflet popup override */
.srv-popup .leaflet-popup-content-wrapper{padding:0;border-radius:12px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.18);}
.srv-popup .leaflet-popup-tip{background:#fff;}
body.dark .srv-popup .leaflet-popup-content-wrapper{background:#1e293b;}
body.dark .srv-popup .leaflet-popup-tip{background:#1e293b;}
.srv-popup .leaflet-popup-content{margin:0;}

/* Popup inner */
.mp-wrap{padding:14px 16px 12px;min-width:200px;font-family:var(--font-main);}
.mp-name a{display:block;font-size:15px;font-weight:700;color:var(--primary);text-decoration:none;margin-bottom:3px;line-height:1.3;}
.mp-name a:hover{text-decoration:underline;}
.mp-spec{font-size:12px;color:var(--text2);margin-bottom:6px;}
.mp-meta{display:flex;align-items:center;gap:6px;font-size:12px;margin-bottom:5px;}
.mp-stars{color:#f59e0b;letter-spacing:1px;font-size:13px;}
.mp-price{color:#16a34a;font-weight:700;font-size:13px;}
.mp-quote{color:var(--primary);font-weight:600;font-size:12px;}
.mp-addr{font-size:11px;color:var(--text2);margin-bottom:8px;}
.mp-addr i{color:var(--primary);margin-right:3px;}
.mp-btn{width:100%;padding:8px 12px;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;font-family:var(--font-main);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:.15s;}
.mp-btn:hover{background:var(--primary-dark,#1d4ed8);}
body.dark .mp-wrap{background:#1e293b;color:var(--text);}
body.dark .mp-name a{color:#60a5fa;}

/* Map results list below map */
.map-results-list{margin-top:0;}
.map-list-header{padding:12px 16px 8px;font-size:13px;color:var(--text2);display:flex;align-items:center;gap:4px;}
.map-list-header b{color:var(--text);}
.map-list-scroll{display:flex;flex-direction:column;gap:0;}
.map-list-card{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:.15s;border-bottom:1px solid var(--border);}
.map-list-card:last-child{border-bottom:none;}
.map-list-card:hover{background:var(--surface-hover,var(--surface));}
.map-list-card:active{transform:scale(.99);}
.map-list-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;}
.map-list-info{flex:1;min-width:0;}
.map-list-info b{display:block;font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.map-list-info span{display:block;font-size:12px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.map-list-price{color:#16a34a !important;font-weight:600 !important;font-size:12px !important;}
.map-list-right{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0;}
.map-list-right small{font-size:11px;color:var(--text2);}
.map-list-arr{font-size:11px;color:var(--text2);margin-top:2px;}

/* ===== PERMISSIONS WIZARD ===== */
.perms-sheet{max-width:400px !important;padding:32px 24px !important;}
.perm-wizard{display:flex;flex-direction:column;align-items:center;text-align:center;gap:0;}
.perm-dots{display:flex;gap:6px;margin-bottom:24px;}
.perm-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:.3s;}
.perm-dot.active{background:var(--primary);width:20px;border-radius:4px;}
.perm-dot.done{background:var(--primary);opacity:.4;}
.perm-icon-wrap{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:20px;}
.perm-icon-wrap i{font-size:34px;}
.perm-wizard h3{font-size:20px;font-weight:700;margin-bottom:10px;}
.perm-wizard p{font-size:14px;color:var(--text2);line-height:1.6;margin-bottom:24px;}
.perm-allow-btn{margin-bottom:10px;}
.perm-counter{font-size:12px;color:var(--text3);margin-top:12px;}

/* ===== DEV CONFIG ENHANCED ===== */
.dev-cfg-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.cfg-env-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:700;}
.cfg-meta-row{display:flex;align-items:center;gap:14px;font-size:12px;color:var(--text2);padding:8px 0 16px;border-bottom:1px solid var(--border);margin-bottom:16px;}
.cfg-meta-row i{color:var(--text3);}
.cfg-hint{font-size:12px;color:var(--text3);background:var(--bg);border-radius:var(--radius-sm);padding:8px 12px;margin-bottom:14px;border-left:3px solid var(--primary);}
.cfg-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin:14px 0 8px;}
.cfg-indent{padding-left:32px;}
.cfg-toggle-row{align-items:center;padding:10px 0;border-bottom:1px solid var(--border);}
.cfg-toggle-row:last-of-type{border-bottom:none;}
.cfg-toggle-info{display:flex;align-items:center;gap:10px;flex:1;}
.cfg-toggle-info i{font-size:18px;width:22px;text-align:center;}
.cfg-toggle-info div{display:flex;flex-direction:column;}
.cfg-toggle-info b{font-size:14px;}
.cfg-toggle-info small{font-size:11px;color:var(--text3);}
.color-input-row{display:flex;align-items:center;gap:10px;}
.color-input-row input[type=color]{width:44px;height:44px;padding:2px;border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:none;}

/* Responsive v3 */
@media(min-width:640px){
  .parts-grid{grid-template-columns:repeat(3,1fr);}
  .stats-grid{grid-template-columns:repeat(4,1fr);}
}
@media(min-width:900px){
  .bottom-nav{display:none;}
  .main-content{padding-bottom:20px;}
  .parts-grid{grid-template-columns:repeat(4,1fr);}
}
