:root{--bg:#F5F8FC;--card:#fff;--line:#E5E7EB;--primary:#2563EB;--primary-dark:#1D4ED8;--dark:#0F172A;--muted:#64748B;--success:#16A34A;--danger:#DC2626;--warning:#F59E0B;--shadow:0 16px 40px rgba(15,23,42,.08)}
*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:Inter,Arial,sans-serif;background:var(--bg);color:var(--dark)}a{text-decoration:none;color:inherit}img{max-width:100%;display:block}
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.9);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav-container{max-width:1240px;margin:0 auto;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px}.logo img{width:58px;height:58px;border-radius:16px;object-fit:cover;box-shadow:var(--shadow)}.nav-links{display:flex;gap:16px;align-items:center;flex-wrap:wrap}.nav-links a{font-weight:600;color:#0f172a}.nav-user{padding:10px 12px;background:#eff6ff;border-radius:999px;color:#1d4ed8;font-weight:700;font-size:.92rem}
.btn,.btn-primary,.btn-secondary,.btn-danger,.btn-light{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 18px;border-radius:14px;font-weight:700;border:none;cursor:pointer;transition:.18s ease}.btn-primary,.btn{background:var(--primary);color:#fff}.btn-primary:hover,.btn:hover{background:var(--primary-dark)}.btn-secondary{background:#fff;border:1px solid #cbd5e1;color:var(--dark)}.btn-light{background:#eff6ff;color:#1d4ed8}.btn-danger{background:#fee2e2;color:#b91c1c}
.flash{max-width:1200px;margin:14px auto;padding:14px 18px;border-radius:16px}.flash-success{background:#dcfce7;color:#166534;border:1px solid #86efac}.flash-error{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}
.hero{max-width:1240px;margin:26px auto 0;padding:0 20px}.hero-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;background:linear-gradient(135deg,#0f172a,#1d4ed8);padding:46px;border-radius:32px;color:#fff;box-shadow:var(--shadow)}.hero h1{font-size:3rem;line-height:1.05;margin:14px 0}.hero p{font-size:1.05rem;line-height:1.7;color:rgba(255,255,255,.88)}.hero-badges{display:flex;gap:10px;flex-wrap:wrap}.badge{display:inline-flex;align-items:center;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18);font-size:.88rem;font-weight:700}.hero-card{background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.12);border-radius:28px;padding:26px;display:flex;flex-direction:column;justify-content:end;min-height:280px}
.section{max-width:1240px;margin:0 auto;padding:34px 20px}.section-head{display:flex;justify-content:space-between;align-items:end;gap:16px;margin-bottom:18px}.section-head h2{margin:0;font-size:2rem}.section-head p{margin:0;color:var(--muted)}
.categories{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}.category-card{background:var(--card);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);padding:18px;text-align:center;transition:.18s ease}.category-card:hover{transform:translateY(-4px);border-color:#BFDBFE}.category-icon{width:56px;height:56px;margin:0 auto 12px;border-radius:16px;background:#EFF6FF;color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:1.6rem}.category-name{font-weight:700}
.products{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:18px}.product-card{background:var(--card);border:1px solid var(--line);border-radius:22px;overflow:hidden;box-shadow:var(--shadow);transition:.18s ease}.product-card:hover{transform:translateY(-4px)}.product-thumb{position:relative;overflow:hidden;background:#f8fafc}.product-card img{width:100%;height:190px;object-fit:cover}.product-chip{position:absolute;top:12px;left:12px;background:rgba(15,23,42,.72);color:#fff;padding:8px 10px;border-radius:999px;font-size:.8rem;font-weight:700}.product-card .content{padding:18px}.product-card h3{margin:0 0 8px;font-size:1.12rem}.product-card p{margin:0 0 12px;color:var(--muted);line-height:1.55}.product-meta{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:10px}.price{font-size:1.1rem;font-weight:800;color:var(--dark)}.card-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.panel-shell{max-width:1280px;margin:26px auto;padding:0 20px;display:grid;grid-template-columns:270px 1fr;gap:22px}.panel-sidebar{background:#0F172A;color:#E5E7EB;border-radius:24px;padding:22px;box-shadow:var(--shadow);position:sticky;top:96px;height:fit-content}.panel-sidebar h2{margin:0 0 6px;color:#fff}.panel-sidebar p{margin:0 0 18px;color:#94A3B8;font-size:.94rem}.panel-nav{display:flex;flex-direction:column;gap:10px}.panel-nav a{padding:12px 14px;border-radius:14px;color:#E5E7EB;font-weight:600}.panel-nav a:hover,.panel-nav a.active{background:#1E293B;color:#fff}.panel-content{background:transparent}
.admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:20px}.stat-card{background:var(--card);border:1px solid var(--line);border-radius:22px;padding:20px;box-shadow:var(--shadow)}.stat-card .label{font-size:.88rem;color:var(--muted);margin-bottom:10px}.stat-card .value{font-size:1.8rem;font-weight:800}.table-card,.form-card,.shell-card{background:var(--card);border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);padding:20px}.table-card h3,.form-card h3{margin:0 0 14px}
table{width:100%;border-collapse:collapse}th,td{padding:12px 10px;border-bottom:1px solid #F1F5F9;text-align:left;font-size:.95rem;vertical-align:top}th{font-size:.83rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.form-grid .full{grid-column:1/-1}
input[type="text"],input[type="email"],input[type="password"],input[type="date"],input[type="time"],input[type="number"],textarea,select{width:100%;padding:13px 14px;border:1px solid #D1D5DB;border-radius:14px;background:#fff;font:inherit;color:var(--dark)}textarea{min-height:120px;resize:vertical}label{display:block;font-weight:600;margin-bottom:8px}
.auth-shell{max-width:560px;margin:40px auto;padding:0 20px}.auth-card{background:var(--card);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);padding:28px}.auth-card h2{margin:0 0 8px}.auth-card p{color:var(--muted)}
.dropzone{border:2px dashed #93C5FD;border-radius:20px;padding:28px;text-align:center;background:#F8FBFF;transition:.2s ease;cursor:pointer}.dropzone.dragover{background:#EFF6FF;border-color:var(--primary)}.dropzone i{font-size:2rem;color:var(--primary);margin-bottom:10px}
.site-footer{margin-top:40px;background:#fff;border-top:1px solid var(--line)}.footer-container{max-width:1200px;margin:0 auto;padding:32px 20px}.footer-centered{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:18px}.footer-main-logo{height:74px;width:74px;border-radius:18px;box-shadow:var(--shadow);margin:0 auto 8px}.airanova-footer-logo{height:54px;margin:10px auto 0}.social-icons{display:flex;gap:14px;justify-content:center;align-items:center}.social-icons a{width:42px;height:42px;border-radius:999px;background:#EFF6FF;color:var(--primary);display:inline-flex;align-items:center;justify-content:center;font-size:1rem;transition:.2s ease}.social-icons a:hover{background:var(--primary);color:#fff;transform:translateY(-2px)}.muted{color:var(--muted)}.empty-state{padding:22px;border:1px dashed var(--line);border-radius:18px;color:var(--muted);text-align:center;background:#fff}.quote-cta{background:linear-gradient(135deg,#E0ECFF,#F8FBFF);border:1px solid #BFDBFE;border-radius:28px;padding:34px;text-align:center;box-shadow:var(--shadow)}
.status-pill{display:inline-flex;padding:8px 12px;border-radius:999px;font-size:.84rem;font-weight:800}.status-pendiente{background:#fef3c7;color:#92400e}.status-aprobada{background:#dcfce7;color:#166534}.status-produccion{background:#dbeafe;color:#1d4ed8}.status-entregado{background:#e9d5ff;color:#6d28d9}.status-cancelada{background:#fee2e2;color:#b91c1c}
.chat-shell{display:grid;grid-template-columns:290px 1fr;gap:20px}.chat-users{background:#fff;border:1px solid var(--line);border-radius:24px;padding:14px;box-shadow:var(--shadow)}.chat-user-item{display:block;padding:14px;border-radius:16px;margin-bottom:8px}.chat-user-item.active,.chat-user-item:hover{background:#eff6ff}.chat-window{background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);overflow:hidden}.chat-head{padding:18px 20px;border-bottom:1px solid #eef2f7;font-weight:800}.chat-body{padding:20px;min-height:380px;max-height:520px;overflow:auto;background:linear-gradient(180deg,#f8fbff,#ffffff)}.chat-bubble{max-width:72%;padding:14px 16px;border-radius:18px;margin-bottom:12px;line-height:1.55;position:relative}.chat-bubble.user{margin-left:auto;background:#dbeafe;border-bottom-right-radius:6px}.chat-bubble.admin{background:#f1f5f9;border-bottom-left-radius:6px}.chat-meta{font-size:.78rem;color:#64748b;margin-top:6px}.chat-compose{display:flex;gap:10px;padding:16px;border-top:1px solid #eef2f7;background:#fff}
.calendar-shell{max-width:1240px;margin:28px auto;padding:0 20px}.calendar-layout{display:grid;grid-template-columns:1.1fr .9fr;gap:22px}.calendar-banner,.calendar-card{background:#fff;border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:28px}.calendar-banner{background:linear-gradient(135deg,#0f172a,#1d4ed8);color:#fff}.calendar-banner p{color:rgba(255,255,255,.85)}.slot-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.slot{padding:12px;border-radius:14px;border:1px solid #cbd5e1;background:#fff;font-weight:700;text-align:center;cursor:pointer}.slot.active{background:#2563eb;color:#fff;border-color:#2563eb}
.timeline{display:grid;gap:14px}.timeline-item{border:1px solid var(--line);border-radius:20px;padding:18px;background:#fff}.timeline-step{display:flex;justify-content:space-between;gap:10px;align-items:center}
.back-link{display:inline-flex;align-items:center;gap:8px;margin-bottom:16px;color:#1d4ed8;font-weight:700}
.feature-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}.feature-item{background:#fff;border:1px solid var(--line);border-radius:20px;padding:18px;box-shadow:var(--shadow)}
@media (max-width:960px){.hero-grid,.panel-shell,.form-grid,.calendar-layout,.chat-shell{grid-template-columns:1fr}.panel-sidebar{position:relative;top:auto}.nav-links{gap:14px}.hero{padding-top:0}.hero-grid{padding:34px 22px}.slot-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.nav-container{flex-direction:column;align-items:flex-start}.nav-links{width:100%;justify-content:flex-start}.hero h1{font-size:2.1rem}.section-head{flex-direction:column;align-items:flex-start}.slot-grid{grid-template-columns:1fr}.chat-bubble{max-width:88%}}

/* v6.2 refinements */
.product-card.compact-media .product-thumb,.work-card .product-thumb,.promo-card .product-thumb{padding:14px 14px 0;background:linear-gradient(180deg,#f8fafc,#fff)}
.product-card.compact-media .product-thumb img,.work-card .product-thumb img,.promo-card .product-thumb img{height:170px;border-radius:18px}
.products.products-compact{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.back-link{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:#1d4ed8;margin-bottom:14px}
.quote-layout{display:grid;grid-template-columns:.92fr 1.08fr;gap:22px}
.quote-visual-card{background:#fff;border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:18px;overflow:hidden}
.quote-visual-card img{width:100%;height:100%;min-height:540px;object-fit:cover;border-radius:22px}
.quote-visual-overlay{margin-top:-140px;position:relative;padding:18px;border-radius:22px;background:rgba(15,23,42,.82);color:#fff;backdrop-filter:blur(8px)}
.quote-visual-overlay p{margin:8px 0 0;color:rgba(255,255,255,.86)}
.calendar-full{display:grid;grid-template-columns:1fr 360px;gap:22px;align-items:start}
.calendar-panel{background:#fff;border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:24px}
.calendar-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;gap:12px}
.calendar-month{font-size:1.25rem;font-weight:800}
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}
.calendar-weekday,.calendar-day{border-radius:18px;padding:14px;text-align:center}
.calendar-weekday{font-size:.82rem;color:var(--muted);font-weight:700;background:#f8fafc}
.calendar-day{border:1px solid var(--line);background:#fff;min-height:108px;display:flex;flex-direction:column;justify-content:space-between;align-items:flex-start;cursor:pointer;transition:.18s ease}
.calendar-day:hover{transform:translateY(-2px);border-color:#bfdbfe}
.calendar-day.muted{opacity:.42}
.calendar-day.active{background:#eff6ff;border-color:#2563eb;box-shadow:inset 0 0 0 2px #bfdbfe}
.calendar-day-num{font-weight:800;font-size:1rem}
.calendar-day-label{font-size:.78rem;color:var(--muted);text-align:left}
.slot-grid.slot-grid-2{grid-template-columns:repeat(2,1fr)}
.slot small{display:block;color:inherit;opacity:.8;font-weight:600;margin-top:4px}
.slot.active small{color:#fff}
.admin-list{display:grid;gap:14px}
.admin-list-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:18px;box-shadow:var(--shadow)}
.admin-list-top{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}
.appointment-badge{display:inline-flex;padding:8px 12px;border-radius:999px;background:#eff6ff;color:#1d4ed8;font-weight:800}
.hero-mini{padding:20px 22px;border-radius:24px;background:linear-gradient(135deg,#0f172a,#2563eb);color:#fff}
.hero-mini p{color:rgba(255,255,255,.88)}
.table-responsive{overflow:auto}
.whatsapp-thread{background:#efeae2;padding:18px;border-radius:24px}
.whatsapp-row{display:flex;margin-bottom:14px}
.whatsapp-row.user{justify-content:flex-end}
.whatsapp-bubble{max-width:76%;padding:13px 14px;border-radius:18px;box-shadow:0 6px 16px rgba(15,23,42,.08);background:#fff}
.whatsapp-row.user .whatsapp-bubble{background:#dcf8c6}
.whatsapp-name{font-size:.82rem;font-weight:800;margin-bottom:6px;color:#0f172a}
.whatsapp-time{font-size:.76rem;color:#64748b;margin-top:8px;text-align:right}
.quote-header-card{background:linear-gradient(135deg,#0f172a,#2563eb);color:#fff;border-radius:28px;padding:28px}
.quote-header-card p{color:rgba(255,255,255,.9)}
@media (max-width: 980px){
  .quote-layout,.calendar-full{grid-template-columns:1fr}
  .quote-visual-card img{min-height:280px}
}

/* v8 stability and layout refinements */
.refined-quote-layout{align-items:start}
.quote-product-preview{display:flex;flex-direction:column;gap:16px;min-height:540px;background:linear-gradient(180deg,#f8fbff,#ffffff)}
.quote-preview-top h2{margin:10px 0 8px;font-size:1.9rem;line-height:1.1}
.badge-dark{background:#0f172a;color:#fff;border-color:#0f172a}
.quote-preview-media{display:flex;align-items:center;justify-content:center;padding:10px 10px 0}
.quote-preview-media img{width:min(100%,420px);max-height:320px;object-fit:contain;border-radius:24px;background:#fff;box-shadow:0 18px 40px rgba(15,23,42,.10);padding:10px}
.quote-preview-note{padding:16px 18px;border-radius:20px;background:#eff6ff;color:#1e3a8a}
.product-card.compact-media .product-thumb img,.work-card .product-thumb img,.promo-card .product-thumb img{height:148px;object-fit:cover}
.promo-card .product-thumb,.work-card .product-thumb{display:flex;align-items:center;justify-content:center}
.promo-card .product-thumb img{max-width:92%;margin:0 auto}
.products .work-card,.products .promo-card{align-self:start}
.calendar-shell-google{max-width:1380px}
.calendar-google-layout{display:grid;grid-template-columns:320px 1fr;gap:22px;align-items:start}
.google-card{background:#fff;border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:20px}
.calendar-google-sidebar{display:grid;gap:18px;position:sticky;top:96px}
.calendar-google-main{padding:18px 18px 22px}
.calendar-google-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.calendar-toolbar-group{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.calendar-grid-head .calendar-weekday{font-size:.8rem;padding:12px 10px;background:#fff;border:0;border-bottom:1px solid #e2e8f0;border-radius:0;color:#64748b}
.calendar-grid-google{grid-template-columns:repeat(7,minmax(120px,1fr));gap:0;border-left:1px solid #e2e8f0;border-top:1px solid #e2e8f0}
.calendar-day-google{background:#fff;min-height:142px;border-right:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0;padding:10px 12px;text-align:left;display:flex;flex-direction:column;gap:14px;transition:.18s ease}
.calendar-day-google:hover{background:#f8fbff}
.calendar-day-google.outside{background:#fafafa;color:#94a3b8}
.calendar-day-google.past{opacity:.56}
.calendar-day-google.active{background:#eef4ff;box-shadow:inset 0 0 0 2px #2563eb}
.calendar-day-top{display:flex;justify-content:space-between;gap:10px;align-items:center}
.calendar-day-num-google{font-size:1.05rem;font-weight:800}
.calendar-day-weekname{font-size:.76rem;color:#64748b;text-transform:capitalize}
.calendar-day-chips{display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.calendar-chip{display:inline-flex;padding:7px 10px;border-radius:999px;font-size:.72rem;font-weight:700}
.calendar-chip.blue{background:#dbeafe;color:#1d4ed8}.calendar-chip.green{background:#dcfce7;color:#166534}.calendar-chip.violet{background:#ede9fe;color:#6d28d9}
.calendar-google-mini .mini-month{font-weight:800;margin-bottom:12px}
.mini-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.mini-day{height:34px;border:none;border-radius:10px;background:#f8fafc;font-weight:700;cursor:pointer}
.mini-day.active{background:#2563eb;color:#fff}.mini-day.past{opacity:.45}.mini-day.blank{background:transparent;cursor:default}
.slot-google{background:#fff;border:1px solid #dbe3ef}.slot-google.active{background:#2563eb;color:#fff}
@media (max-width:1100px){.calendar-google-layout{grid-template-columns:1fr}.calendar-google-sidebar{position:relative;top:auto}.calendar-grid-google{grid-template-columns:repeat(7,minmax(92px,1fr))}}
@media (max-width:780px){.calendar-grid-google{grid-template-columns:repeat(2,1fr);border:none;gap:10px}.calendar-day-google{min-height:110px;border:1px solid #e2e8f0;border-radius:18px}.calendar-grid-head{display:none}.calendar-google-main{padding:18px}.mini-grid{gap:6px}}


.field-help{display:block;margin-top:6px;color:var(--muted);font-size:.82rem;line-height:1.45}
.password-wrap{position:relative}
.password-wrap input{padding-right:52px}
.password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);border:none;background:transparent;color:#64748b;font-size:1rem;cursor:pointer;width:36px;height:36px;border-radius:999px}
.password-toggle:hover{background:#f1f5f9;color:#0f172a}
.whatsapp-float{position:fixed;right:18px;bottom:18px;z-index:80;display:inline-flex;align-items:center;gap:10px;background:#25D366;color:#fff;padding:14px 18px;border-radius:999px;box-shadow:0 18px 35px rgba(15,23,42,.24);font-weight:800}
.whatsapp-float i{font-size:1.3rem}
.whatsapp-float:hover{transform:translateY(-2px)}
.products img,.quote-preview-media img,.product-thumb img{image-rendering:auto}
@media (max-width:640px){.whatsapp-float span{display:none}.whatsapp-float{padding:14px}}

body{overflow-x:hidden}
img{height:auto}
.nav-links .btn-primary,.card-actions .btn-primary{background:linear-gradient(135deg,#2563eb,#1d4ed8)}
.btn-secondary{background:#f8fbff;border-color:#bfd7ff;color:#1e3a8a}
.btn-light{background:#fff7ed;color:#c2410c}
.timeline-item,.admin-list-card{overflow:hidden}
.tracking-timeline{gap:18px}.tracking-card{border:1px solid #dbeafe;background:linear-gradient(180deg,#ffffff,#f8fbff)}
.tracking-body,.quote-admin-body{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:14px}
.tracking-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:#64748b;font-weight:800}
.quote-admin-form{margin-top:16px;padding-top:14px;border-top:1px solid #e5e7eb}
.quote-admin-form select,.quote-admin-form textarea{width:100%}
.promo-admin-card{border-left:4px solid #fb923c}
.whatsapp-float.icon-only{width:60px;height:60px;padding:0;justify-content:center}.whatsapp-float.icon-only i{font-size:1.55rem}
.site-header,.site-footer,.panel-shell,.section,.hero,.products,.categories,.feature-list{max-width:100%}
.product-card img,.work-card img,.promo-card img,.quote-preview-media img{loading:lazy}
@media (max-width:780px){
  .tracking-body,.quote-admin-body{grid-template-columns:1fr}
  .nav-links{overflow-x:auto;white-space:nowrap;max-width:100%;padding-bottom:4px}
  .nav-links a,.nav-user{flex:0 0 auto}
  .products{grid-template-columns:1fr}
  .categories{grid-template-columns:repeat(2,minmax(0,1fr))}
  .hero-grid,.quote-header-card,.quote-cta,.table-card,.form-card,.auth-card{border-radius:22px}
  .quote-preview-top h2{font-size:1.5rem}
}

/* v18 pro admin experience */
:root{--accent-2:#7c3aed;--glass:rgba(255,255,255,.72);--glass-border:rgba(255,255,255,.45)}
.app-body{min-height:100vh;background:radial-gradient(circle at top left,rgba(59,130,246,.12),transparent 28%),radial-gradient(circle at top right,rgba(124,58,237,.08),transparent 24%),var(--bg)}
.site-backdrop{position:fixed;inset:0;pointer-events:none;background:linear-gradient(180deg,rgba(255,255,255,.35),transparent 22%);z-index:-1}
.glass-card{background:var(--glass);backdrop-filter:blur(18px);border:1px solid var(--glass-border);box-shadow:0 18px 55px rgba(15,23,42,.08)}
.eyebrow{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:#eff6ff;color:#1d4ed8;font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.nav-pill{padding:11px 16px;border-radius:16px;font-weight:800}
.primary-pill{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff !important;box-shadow:0 16px 30px rgba(37,99,235,.24)}
.dark-pill{background:linear-gradient(135deg,#0f172a,#1e293b);color:#fff !important;box-shadow:0 16px 30px rgba(15,23,42,.24)}
.nav-icon-btn{position:relative;width:42px;height:42px;border:none;border-radius:14px;background:#fff;box-shadow:0 10px 24px rgba(15,23,42,.08);display:inline-flex;align-items:center;justify-content:center;color:#0f172a;cursor:pointer;transition:.2s ease}
.nav-icon-btn:hover{transform:translateY(-2px);background:#eff6ff;color:#1d4ed8}
.notif-badge{position:absolute;top:-6px;right:-6px;min-width:22px;height:22px;padding:0 6px;border-radius:999px;background:#ef4444;color:#fff;font-size:.72rem;font-weight:800;display:flex;align-items:center;justify-content:center}
.notif-drawer{position:fixed;inset:0;background:rgba(15,23,42,.36);display:none;align-items:flex-start;justify-content:flex-end;padding:88px 18px 18px;z-index:110}
.notif-drawer.open{display:flex}
.notif-card{width:min(420px,100%);border-radius:28px;padding:20px;max-height:calc(100vh - 110px);overflow:auto}
.notif-head{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:14px}.notif-head h3{margin:6px 0 0}
.notif-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px}
.notif-mini{padding:14px;border-radius:18px;background:#f8fbff;border:1px solid #dbeafe;text-align:center}.notif-mini strong{display:block;font-size:1.3rem}.notif-mini span{display:block;font-size:.8rem;color:var(--muted);margin-top:6px}
.notif-list{display:grid;gap:10px}.notif-item{display:grid;grid-template-columns:46px 1fr;gap:12px;padding:14px;border-radius:18px;background:#fff;border:1px solid #eef2f7}.notif-item p{margin:6px 0 0;color:var(--muted)}.notif-icon{width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1rem}.notif-item.blue .notif-icon{background:#dbeafe;color:#1d4ed8}.notif-item.green .notif-icon{background:#dcfce7;color:#166534}.notif-item.violet .notif-icon{background:#ede9fe;color:#6d28d9}
.sidebar-toggle-note{font-size:.8rem;padding:10px 12px;border-radius:14px;background:rgba(255,255,255,.08);color:#cbd5e1;margin-bottom:14px}
.admin-saas-space{display:grid;gap:22px}
.saas-hero{display:grid;grid-template-columns:1.15fr .85fr;gap:22px;padding:30px;border-radius:30px;background:linear-gradient(135deg,rgba(15,23,42,.95),rgba(37,99,235,.82),rgba(124,58,237,.78));color:#fff;position:relative;overflow:hidden}
.saas-hero::after{content:"";position:absolute;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.16),transparent 68%);top:-80px;right:-80px}
.saas-hero h1{margin:10px 0 12px;font-size:2.4rem;line-height:1.04}.saas-hero p{color:rgba(255,255,255,.86);max-width:640px}
.hero-inline-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.saas-hero-side{display:flex;align-items:stretch}.orbital-card{margin-left:auto;width:100%;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:28px;padding:22px;backdrop-filter:blur(16px)}
.orbital-badge{display:inline-flex;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.16);font-weight:800}.orbital-grid{margin-top:18px;display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.orbital-grid strong{display:block;font-size:1.9rem}.orbital-grid span{display:block;color:rgba(255,255,255,.82);font-size:.9rem;margin-top:4px}
.saas-stats-grid .saas-stat{position:relative;overflow:hidden}.saas-stat::after{content:"";position:absolute;inset:auto -20px -50px auto;width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,.3)}.saas-stat.blue{background:linear-gradient(135deg,#eff6ff,#ffffff)}.saas-stat.indigo{background:linear-gradient(135deg,#eef2ff,#ffffff)}.saas-stat.emerald{background:linear-gradient(135deg,#ecfdf5,#ffffff)}.saas-stat.amber{background:linear-gradient(135deg,#fff7ed,#ffffff)}
.dashboard-grid-2{display:grid;grid-template-columns:1.1fr .9fr;gap:22px}.lower-grid{grid-template-columns:.95fr 1.05fr}
.card-head-between{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:16px}.card-head-between h3,.card-head-between h2{margin:6px 0 0}.chip{display:inline-flex;padding:8px 12px;border-radius:999px;background:#eff6ff;color:#1d4ed8;font-size:.8rem;font-weight:800}.chip.dark{background:#0f172a;color:#fff}.chip.success{background:#dcfce7;color:#166534}
.chart-card,.status-card,.top-products-card,.alerts-card{border-radius:28px}
.chart-bars.duo-chart{display:flex;align-items:flex-end;gap:18px;min-height:260px;padding-top:10px}.bar-group{display:flex;flex-direction:column;gap:10px;align-items:center;flex:1}.bar-stack{display:flex;align-items:flex-end;gap:8px;height:190px}.bar{width:18px;border-radius:999px 999px 6px 6px;display:block;box-shadow:0 12px 20px rgba(15,23,42,.08)}.bar.q{background:linear-gradient(180deg,#2563eb,#1d4ed8)}.bar.c{background:linear-gradient(180deg,#7c3aed,#8b5cf6)}.bar-group strong{font-size:.9rem}.bar-group small{color:var(--muted);text-align:center;line-height:1.4}
.status-list-pro{display:grid;gap:16px}.status-row-pro{display:grid;gap:10px}.status-headline{display:flex;justify-content:space-between;gap:12px;align-items:center}.progress-line{height:10px;border-radius:999px;background:#eef2f7;overflow:hidden}.progress-line .fill{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#2563eb,#60a5fa)}.fill-aprobada{background:linear-gradient(90deg,#16a34a,#4ade80)}.fill-produccion{background:linear-gradient(90deg,#2563eb,#60a5fa)}.fill-entregado{background:linear-gradient(90deg,#7c3aed,#c084fc)}.fill-cancelada{background:linear-gradient(90deg,#ef4444,#fca5a5)}.fill-pendiente{background:linear-gradient(90deg,#f59e0b,#fcd34d)}
.top-products-list{display:grid;gap:14px}.top-product-row{display:grid;gap:10px;padding:14px 16px;border-radius:18px;background:#fff;border:1px solid #eef2f7}.top-product-row strong{display:block}.top-product-row small{display:block;margin-top:4px;color:var(--muted)}.mini-progress{height:10px;border-radius:999px;background:#eef2f7;overflow:hidden}.mini-progress span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#0f172a,#2563eb)}
.admin-notifications-thread{background:linear-gradient(180deg,#edf6ff,#ffffff);border:1px solid #dbeafe}.admin-notifications-thread .whatsapp-bubble{border-radius:22px}
.panel-sidebar,.table-card,.form-card,.shell-card,.stat-card,.hero-card,.hero-mini,.calendar-banner,.calendar-card,.quote-visual-card,.quote-header-card,.product-card,.category-card,.tracking-card{transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s ease,border-color .3s ease,background .3s ease}.panel-sidebar:hover,.table-card:hover,.form-card:hover,.shell-card:hover,.stat-card:hover,.product-card:hover,.category-card:hover,.tracking-card:hover{transform:translateY(-3px)}
/* dark mode */
body.dark-mode{--bg:#07111f;--card:#0e1728;--line:#213047;--dark:#eef4ff;--muted:#9fb0c9;--shadow:0 18px 44px rgba(2,6,23,.42);--glass:rgba(10,18,33,.78);--glass-border:rgba(74,96,130,.34)}
body.dark-mode .site-header,body.dark-mode .site-footer{background:rgba(8,15,28,.82);border-color:#1f2d44}
body.dark-mode .nav-links a,body.dark-mode .nav-icon-btn,body.dark-mode .btn-secondary,body.dark-mode .btn-light,body.dark-mode .btn-danger,body.dark-mode .table-card,body.dark-mode .form-card,body.dark-mode .shell-card,body.dark-mode .stat-card,body.dark-mode .product-card,body.dark-mode .category-card,body.dark-mode .calendar-card,body.dark-mode .quote-visual-card,body.dark-mode .quote-product-preview,body.dark-mode .timeline-item,body.dark-mode .chat-users,body.dark-mode .chat-window,body.dark-mode .dropzone,body.dark-mode .calendar-panel,body.dark-mode .google-card,body.dark-mode .admin-list-card,body.dark-mode .whatsapp-thread,body.dark-mode .tracking-card,body.dark-mode .notif-card{color:var(--dark);background:#0e1728;border-color:#1f2d44}
body.dark-mode input,body.dark-mode textarea,body.dark-mode select{background:#091220;border-color:#25344f;color:#eef4ff}
body.dark-mode .nav-user{background:#11203b;color:#8fb3ff}
body.dark-mode .category-icon,body.dark-mode .social-icons a,body.dark-mode .quote-preview-note{background:#11203b;color:#8fb3ff}
body.dark-mode .btn-secondary{background:#10223d;color:#b9d2ff;border-color:#26466d}.btn-secondary:hover{opacity:.96}
body.dark-mode .btn-light{background:#2a1706;color:#ffbf75}
body.dark-mode .progress-line,body.dark-mode .mini-progress{background:#132237}
body.dark-mode .whatsapp-thread{background:linear-gradient(180deg,#081423,#0e1728)}
body.dark-mode .whatsapp-row.user .whatsapp-bubble{background:#173a26;color:#eaffee}
body.dark-mode .whatsapp-bubble{background:#101c31;color:#eef4ff}
body.dark-mode .calendar-weekday,body.dark-mode .calendar-day-google.outside{background:#0a1323}
body.dark-mode .calendar-day-google{border-color:#24354f;background:#0e1728}
body.dark-mode .calendar-day-google:hover,body.dark-mode .calendar-day.active{background:#11203b}
body.dark-mode .notif-mini{background:#0f1a2d;border-color:#1f2d44}
body.dark-mode .notif-item{background:#0f1a2d;border-color:#1f2d44}
body.dark-mode .empty-state{background:#0d1728;border-color:#24354f;color:#9fb0c9}
@media (max-width:1100px){.saas-hero,.dashboard-grid-2,.lower-grid{grid-template-columns:1fr}.saas-hero h1{font-size:2rem}.orbital-card{margin-left:0}}
@media (max-width:780px){.notif-drawer{padding:76px 10px 10px}.notif-stats{grid-template-columns:1fr}.chart-bars.duo-chart{overflow:auto;align-items:flex-end;padding-bottom:8px}.bar-group{min-width:68px}.hero-inline-actions{flex-direction:column}.saas-hero{padding:24px}.nav-container{align-items:flex-start}.nav-links{gap:10px}.nav-icon-btn{flex:0 0 auto}}


/* v19 professional polish */
:root{--glass:rgba(255,255,255,.78);--glass-border:rgba(191,219,254,.55);}
.site-backdrop{position:fixed;inset:0;pointer-events:none;background:
 radial-gradient(1200px 500px at 10% -10%, rgba(59,130,246,.14), transparent 60%),
 radial-gradient(900px 420px at 100% 0%, rgba(37,99,235,.12), transparent 55%),
 linear-gradient(180deg, rgba(248,250,252,.7), rgba(245,248,252,1));z-index:-1}
.nav-links{flex:1;justify-content:flex-end}
.nav-tools{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.hero-grid,.saas-hero{position:relative;overflow:hidden}
.hero-grid::before,.saas-hero::before{content:"";position:absolute;inset:-20% auto auto -10%;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.16),transparent 68%);animation:floatGlow 14s ease-in-out infinite}
.hero-grid::after,.saas-hero::after{animation:floatGlow 18s ease-in-out infinite reverse}
@keyframes floatGlow{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(18px,12px,0) scale(1.05)}}
@keyframes stripeLift{0%{transform:translateY(0);opacity:.96}50%{transform:translateY(-4px);opacity:1}100%{transform:translateY(0);opacity:.96}}
@keyframes shimmerSweep{0%{transform:translateX(-120%) skewX(-18deg)}100%{transform:translateX(220%) skewX(-18deg)}}
.stripe-motion{position:relative;overflow:hidden}
.stripe-motion::after{content:"";position:absolute;top:-20%;bottom:-20%;width:120px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.11),transparent);animation:shimmerSweep 7.5s ease-in-out infinite;pointer-events:none}
.btn-primary,.btn,.primary-pill{background:linear-gradient(135deg,#2563eb,#1d4ed8 55%,#0f3fb6);box-shadow:0 14px 34px rgba(37,99,235,.24)}
.btn-secondary{background:linear-gradient(135deg,#ffffff,#eef4ff);border-color:#bfd9ff;color:#14326b}
.btn-light{background:linear-gradient(135deg,#eff6ff,#dbeafe);color:#1746a2}
.btn-danger{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}
.category-card,.product-card,.feature-item,.table-card,.form-card,.shell-card,.stat-card,.google-card,.timeline-item,.chat-users,.chat-window,.calendar-card,.quote-visual-card,.quote-header-card{background:linear-gradient(180deg,#ffffff,#f6faff);border-color:#d9e7ff}
.hero-card-centered{justify-content:center;align-items:center;text-align:center;min-height:220px;padding:30px 34px;background:linear-gradient(180deg,rgba(255,255,255,.14),rgba(255,255,255,.09));animation:stripeLift 11s ease-in-out infinite}
.hero-card-centered h3,.hero-card-centered p{max-width:540px}
.hero-card-centered p{margin:0 auto;color:rgba(255,255,255,.94)!important;font-size:1.15rem;line-height:1.7}
.shell-card{background:linear-gradient(180deg,#ffffff,#f4f9ff)}
.about-highlight{background:linear-gradient(135deg,#edf4ff,#dcecff);border-color:#bfd9ff}
.quote-cta{background:linear-gradient(135deg,#edf4ff,#f7fbff);border-color:#cfe0ff}
.notif-card{background:linear-gradient(180deg,#ffffff,#f4f9ff);border-color:#dbeafe}
.notif-item{align-items:center}
.notif-head{align-items:center}
.tracking-card{background:linear-gradient(180deg,#ffffff,#f2f8ff);border-color:#cfe0ff}
.tracking-step-pro{align-items:center;gap:16px}
.tracking-item-left{display:flex;align-items:center;gap:14px;min-width:0}
.tracking-thumb{width:64px;height:64px;border-radius:18px;object-fit:cover;box-shadow:0 12px 24px rgba(15,23,42,.12);border:2px solid rgba(255,255,255,.7);flex:0 0 auto}
.status-pill{box-shadow:inset 0 1px 0 rgba(255,255,255,.5),0 10px 20px rgba(15,23,42,.06)}
.panel-shell{gap:24px}
.panel-sidebar{background:linear-gradient(180deg,#0b1324,#12233f)}
.top-product-row,.notif-item,.timeline-item{box-shadow:0 12px 28px rgba(15,23,42,.04)}
.whatsapp-thread{background:linear-gradient(180deg,#eef7ff,#ffffff);border:1px solid #dbeafe}
.form-card h3,.table-card h3,.shell-card h2,.shell-card h3{letter-spacing:-.02em}
.hero-grid .card-actions,.saas-hero .hero-inline-actions{position:relative;z-index:1}
.eyebrow:empty{min-height:14px;display:block}
@media (max-width:900px){.nav-links{justify-content:flex-start}.nav-tools{width:100%;justify-content:flex-start}.hero-card-centered{min-height:unset;padding:24px}.tracking-step-pro{align-items:flex-start}.tracking-item-left{width:100%}}
@media (max-width:640px){.tracking-item-left{align-items:flex-start}.tracking-thumb{width:54px;height:54px;border-radius:16px}.hero-grid,.saas-hero{padding:26px}.hero-card-centered p{font-size:1.03rem}.feature-item,.table-card,.form-card,.shell-card,.stat-card{padding:18px}}


/* v20 polish */
.contact-shell-pro{max-width:1100px;margin:0 auto;background:linear-gradient(135deg,#2142a6 0%,#2f57c8 55%,#5a84ff 100%);color:#fff;border-radius:34px;padding:34px;box-shadow:0 24px 60px rgba(29,78,216,.22);border:1px solid rgba(255,255,255,.12)}
.contact-shell-pro h2,.contact-shell-pro p{color:#fff}.contact-shell-pro .muted{color:rgba(255,255,255,.9)}
.contact-shell-pro .card-actions{justify-content:center}.contact-shell-pro .btn-secondary{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.18)}
.contact-shell-pro .btn-secondary:hover{background:rgba(255,255,255,.22)}
.contact-shell-pro .btn-primary{background:#fff;color:#1d4ed8}.contact-shell-pro .btn-primary:hover{background:#eff6ff}
.products.products-compact{grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}
.products.products-compact .product-card.compact-media .product-thumb img{height:132px}
.category-grid-visual .category-card{background:linear-gradient(180deg,#f8fbff,#edf4ff);border-color:#dbeafe}
.hero-card-centered{min-height:180px;padding:26px 28px}
.hero-card-centered h3{font-size:2rem;margin-bottom:10px}.hero-card-centered p{max-width:640px;font-size:1.1rem}
.quote-visual-card.quote-product-preview{background:linear-gradient(180deg,#eef4ff,#ffffff)}
.orbital-badge{gap:8px;justify-content:center}
.sidebar-toggle-note{display:none}
.quote-custom-tip{margin-top:14px;padding:14px 16px;border-radius:16px;background:#eef4ff;color:#1e3a8a;border:1px solid #c7ddff;font-size:.95rem}
@media (max-width:980px){.products.products-compact{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:640px){.products.products-compact{grid-template-columns:1fr}.contact-shell-pro{padding:24px;border-radius:28px}}


.story-shell-pro{max-width:1100px;margin:0 auto;background:linear-gradient(135deg,#2142a6 0%,#2f57c8 55%,#5a84ff 100%);color:#fff;border-radius:34px;padding:34px;box-shadow:0 24px 60px rgba(29,78,216,.22);border:1px solid rgba(255,255,255,.12)}
.story-shell-pro h2,.story-shell-pro h3,.story-shell-pro p{color:#fff}.story-shell-pro p{line-height:1.72}.story-shell-pro .back-link{color:#fff}.story-shell-pro .muted{color:rgba(255,255,255,.9)}
.about-focus-card{margin-top:24px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);border-radius:28px;padding:24px;backdrop-filter:blur(6px)}
.about-focus-card p{margin:0;color:rgba(255,255,255,.95)}
.contact-shell-pro,.story-shell-pro{position:relative;overflow:hidden}
.contact-shell-pro::before,.story-shell-pro::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(255,255,255,.18),transparent 30%),radial-gradient(circle at bottom left,rgba(255,255,255,.12),transparent 28%);pointer-events:none}
.contact-shell-pro > *, .story-shell-pro > *{position:relative;z-index:1}
@media (max-width:640px){.story-shell-pro{padding:24px;border-radius:28px}}


/* v24 works grid fix */
.works-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;align-items:start}
.works-grid .work-card{width:100%;max-width:none}
.works-grid .work-card .product-thumb{padding:12px 12px 0;background:linear-gradient(180deg,#f8fafc,#fff)}
.works-grid .work-card .product-thumb img{width:100%;height:132px;object-fit:cover;border-radius:18px}
@media (max-width:980px){.works-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:640px){.works-grid{grid-template-columns:1fr}}


/* v25 nav layout fix */
.nav-container{max-width:1280px;padding:14px 24px;display:grid;grid-template-columns:auto 1fr;align-items:center;gap:20px}
.nav-shell{display:flex;align-items:center;justify-content:space-between;gap:24px;min-width:0}
.nav-main{display:flex;align-items:center;justify-content:center;gap:18px;flex:1;flex-wrap:wrap}
.nav-main a{font-weight:700;white-space:nowrap}
.nav-tools{display:flex;align-items:center;justify-content:flex-end;gap:12px;flex-wrap:wrap}
.nav-toggle{display:none;border:1px solid #dbeafe;background:#fff;color:#0f172a;width:46px;height:46px;border-radius:14px;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow)}
.nav-logout{font-weight:700;white-space:nowrap}
.nav-cta{padding-inline:20px}
@media (min-width:981px){.nav-shell{display:flex !important}}
@media (max-width:1200px){.nav-main{gap:14px}.nav-tools{gap:10px}.nav-user{font-size:.88rem;padding:9px 11px}}
@media (max-width:980px){
  .nav-container{grid-template-columns:auto auto;justify-content:space-between;padding:14px 16px;gap:14px}
  .nav-toggle{display:inline-flex}
  .nav-shell{display:none;grid-column:1 / -1;flex-direction:column;align-items:stretch;padding:14px;margin-top:6px;background:rgba(255,255,255,.96);border:1px solid #dbeafe;border-radius:22px;box-shadow:0 22px 48px rgba(15,23,42,.12)}
  .nav-shell.is-open{display:flex}
  .nav-main{justify-content:flex-start;flex-direction:column;align-items:stretch;gap:8px}
  .nav-main a{padding:12px 14px;border-radius:14px;background:#f8fbff}
  .nav-main a.btn-primary{background:linear-gradient(135deg,#2563eb,#1d4ed8 55%,#0f3fb6);color:#fff}
  .nav-tools{justify-content:flex-start;gap:10px;padding-top:10px;border-top:1px solid #e5edf9}
  .nav-user{order:10;width:100%;text-align:center}
  .nav-logout{padding:12px 14px;border-radius:14px;background:#f8fbff}
}
@media (max-width:640px){
  .logo img{width:52px;height:52px}
  .nav-tools{flex-wrap:wrap}
  .nav-tools .nav-pill,.nav-tools .nav-icon-btn,.nav-tools .nav-logout{flex:0 0 auto}
  .nav-tools .nav-user{font-size:.84rem}
}

.quote-product-preview.quote-custom-active{background:linear-gradient(180deg,#eef4ff,#f8fbff)}
.quote-product-preview.quote-custom-active .quote-preview-media img{width:min(100%,260px);max-height:260px;object-fit:contain;background:radial-gradient(circle at top,#ffffff 0%,#f1f5ff 100%);padding:18px;border:1px solid #dbe7ff;box-shadow:0 22px 48px rgba(37,99,235,.12)}
.quote-product-preview.quote-custom-active .quote-preview-top .badge{background:#dbeafe;color:#1d4ed8}


.product-gallery-strip{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,92px));gap:12px;margin-top:14px;justify-content:flex-start}
.product-thumb-btn{width:92px;height:92px;border:1px solid #dbeafe;background:#fff;border-radius:16px;padding:0;overflow:hidden;cursor:pointer;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease;display:flex;align-items:center;justify-content:center}
.product-thumb-btn:hover{transform:translateY(-2px);border-color:#93c5fd;box-shadow:0 10px 24px rgba(37,99,235,.12)}
.product-thumb-btn.active{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.product-thumb-btn img{display:block;width:100%;height:100%;object-fit:cover}
@media (max-width: 720px){.product-gallery-strip{grid-template-columns:repeat(3,84px);gap:10px}.product-thumb-btn{width:84px;height:84px}}

.btn-sm{padding:10px 14px;border-radius:12px;font-size:.88rem}


/* v32 catalog image consistency + responsive polish */
.products.products-compact{grid-template-columns:repeat(auto-fit,minmax(270px,1fr));align-items:stretch}
.products.products-compact .product-card{display:flex;flex-direction:column;height:100%}
.products.products-compact .product-card .content{display:flex;flex-direction:column;flex:1}
.products.products-compact .card-actions{margin-top:auto}
.products.products-compact .product-thumb{padding:14px;background:linear-gradient(180deg,#f3f8ff,#ffffff);min-height:220px;display:flex;align-items:center;justify-content:center}
.products.products-compact .product-thumb img{display:block;width:100%;max-width:240px;height:180px !important;object-fit:cover;object-position:center center;border-radius:18px;box-shadow:0 12px 28px rgba(15,23,42,.10);margin:0 auto}
.products.products-compact .product-card h3{min-height:2.8em}
.products.products-compact .product-card p{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-height:4.5em}
@media (max-width: 1024px){.products.products-compact{grid-template-columns:repeat(2,minmax(0,1fr))}.products.products-compact .product-thumb{min-height:208px}.products.products-compact .product-thumb img{max-width:220px;height:170px !important}}
@media (max-width: 640px){.products.products-compact{grid-template-columns:1fr;gap:14px}.products.products-compact .product-card{border-radius:20px}.products.products-compact .product-thumb{min-height:190px;padding:12px}.products.products-compact .product-thumb img{max-width:200px;height:156px !important;border-radius:16px}.products.products-compact .product-card .content{padding:16px}.products.products-compact .product-card h3{min-height:auto;font-size:1.04rem}.products.products-compact .product-card p{min-height:auto;-webkit-line-clamp:2}}


/* v35 compact home promotions + product admin edit */
.promo-grid-home{grid-template-columns:repeat(auto-fit,minmax(220px,280px));justify-content:flex-start;align-items:start}
.promo-grid-home .promo-card{max-width:280px}
.promo-grid-home .promo-card .product-thumb{padding:12px 12px 0;min-height:auto}
.promo-grid-home .promo-card .product-thumb img{width:100%;height:120px !important;max-width:100%;object-fit:cover;border-radius:16px;display:block}
.promo-grid-home .promo-card .content{padding:14px 16px 16px}
.promo-grid-home .promo-card h3{font-size:1rem;margin-bottom:6px}
.promo-grid-home .promo-card p{font-size:.94rem;line-height:1.45;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-height:4.1em}
@media (max-width: 640px){
  .promo-grid-home{grid-template-columns:1fr 1fr;gap:12px}
  .promo-grid-home .promo-card{max-width:none}
  .promo-grid-home .promo-card .product-thumb img{height:104px !important}
  .promo-grid-home .promo-card .content{padding:12px}
}
@media (max-width: 420px){
  .promo-grid-home{grid-template-columns:1fr}
}
