:root{
  --bg:#f5f8fb; --bg2:#e9eef4; --panel:#ffffff; --soft:#f1f6fb;
  --navy:#0e2a47; --navy2:#15375b; --teal:#1496ac; --teal-deep:#0d7384;
  --gold:#c39a4d; --gold-soft:#dcc187; --ink:#16242f; --muted:#647688;
  --line:#e3eaf1; --green:#1f9e6f; --red:#cf4d46;
  --font-display:'Playfair Display',Georgia,'Times New Roman',serif;
  --font-ui:'Montserrat','Segoe UI',system-ui,-apple-system,sans-serif;
  --shadow:0 10px 30px rgba(14,42,71,.08);
}
*{box-sizing:border-box}
html,body{margin:0;min-height:100%}
body{background:var(--bg);color:var(--ink);font-family:var(--font-ui);font-weight:400;letter-spacing:.1px;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--font-display);font-weight:600;letter-spacing:.2px}

/* ===== Topbar ===== */
.topbar{display:flex;align-items:center;gap:22px;background:#fff;border-bottom:1px solid var(--line);
  padding:14px 30px;position:sticky;top:0;z-index:10;box-shadow:0 1px 14px rgba(14,42,71,.05)}
.flomar-logo{display:flex;flex-direction:column;line-height:1;position:relative;padding-bottom:5px}
.flomar-logo .w{font-family:var(--font-display);font-weight:700;font-size:30px;letter-spacing:-.3px}
.flomar-logo .flo{color:var(--navy)}.flomar-logo .mar{color:var(--teal)}
.flomar-logo .tag{font-size:8px;letter-spacing:4px;color:var(--gold);font-weight:700;margin-top:3px;text-transform:uppercase}
.flomar-logo::after{content:"";position:absolute;left:2px;bottom:0;width:34px;height:2px;background:linear-gradient(90deg,var(--gold),transparent)}

.seg-toggle{display:flex;gap:4px;margin-left:6px;background:var(--soft);border:1px solid var(--line);border-radius:999px;padding:4px}
.seg-toggle button{border:none;background:transparent;color:var(--muted);border-radius:999px;padding:7px 16px;font-family:var(--font-ui);font-weight:600;font-size:12px;cursor:pointer;letter-spacing:.3px;transition:.15s}
.seg-toggle button.on{background:var(--teal);color:#fff;box-shadow:0 2px 8px rgba(20,150,172,.35)}
.seg-toggle button.on.may{background:var(--navy)}
.spacer{flex:1}
.cart-btn{position:relative;border:1px solid var(--navy);background:#fff;color:var(--navy);border-radius:999px;
  padding:9px 18px;font-family:var(--font-ui);font-weight:600;font-size:12.5px;cursor:pointer;display:flex;align-items:center;gap:8px;letter-spacing:.3px;transition:.15s}
.cart-btn:hover{background:var(--navy);color:#fff}
.cart-btn .badge{background:var(--gold);color:#fff;border-radius:999px;font-size:11px;padding:1px 8px;font-weight:700}

.container{max-width:1200px;margin:0 auto;padding:30px 30px 60px}

/* ===== Hero ===== */
.hero{position:relative;overflow:hidden;background:
   radial-gradient(120% 140% at 85% -20%,rgba(20,150,172,.45),transparent 55%),
   radial-gradient(90% 120% at 0% 120%,rgba(195,154,77,.22),transparent 50%),
   linear-gradient(120deg,var(--navy) 0%,var(--navy2) 60%,#1a4368 100%);
  color:#fff;border-radius:22px;padding:64px 56px;margin-bottom:40px;box-shadow:0 20px 50px rgba(14,42,71,.30)}
.hero::after{content:"";position:absolute;inset:0;opacity:.10;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='28' viewBox='0 0 120 28'%3E%3Cpath d='M0 14 C 20 2, 40 26, 60 14 S 100 2, 120 14' fill='none' stroke='%23ffffff' stroke-width='1.4'/%3E%3C/svg%3E");
  background-size:120px 28px}
.hero-eyebrow{position:relative;display:inline-block;font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--gold-soft);font-weight:700;margin-bottom:16px}
.hero h1{position:relative;margin:0 0 14px;font-size:3rem;line-height:1.08;font-weight:700;max-width:16ch}
.hero p{position:relative;margin:0;opacity:.92;font-size:1.05rem;max-width:46ch;font-weight:300}
.hero .seg-info{position:relative;margin-top:22px;font-size:.72rem;letter-spacing:2px;text-transform:uppercase;background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.22);display:inline-block;padding:8px 16px;border-radius:999px;font-weight:600}
.hero .seg-info b{color:var(--gold-soft)}

/* ===== Toolbar ===== */
.toolbar{display:flex;align-items:center;gap:14px;margin-bottom:30px;flex-wrap:wrap}
.search{flex:1;min-width:220px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:13px 22px;font-size:14px;font-family:var(--font-ui);box-shadow:var(--shadow)}
.search:focus{outline:none;border-color:var(--teal)}

/* ===== Catálogo ===== */
.cat-h{font-size:1.55rem;color:var(--navy);margin:38px 0 18px;display:flex;align-items:center;gap:16px;font-weight:600}
.cat-h::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--gold-soft),var(--line) 40%,transparent)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(258px,1fr));gap:24px}
.pcard{background:var(--panel);border:1px solid var(--line);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;
  box-shadow:var(--shadow);transition:.22s ease}
.pcard:hover{transform:translateY(-4px);box-shadow:0 22px 44px rgba(14,42,71,.16);border-color:var(--gold-soft)}
.pimg{height:158px;display:flex;align-items:center;justify-content:center;font-size:66px;position:relative;
  background:radial-gradient(circle at 50% 38%,#eaf4f8,#dce8f1);text-shadow:0 6px 16px rgba(14,42,71,.18)}
.pimg::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(14,42,71,.06))}
.pimg-foto{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pimg .dest{position:absolute;top:12px;left:12px;background:var(--gold);color:#fff;font-size:9px;font-weight:700;
  padding:4px 11px;border-radius:999px;letter-spacing:1.2px;box-shadow:0 4px 10px rgba(195,154,77,.4)}
.pbody{padding:18px 18px 20px;display:flex;flex-direction:column;gap:8px;flex:1}
.pcat{font-size:9.5px;color:var(--teal-deep);font-weight:700;letter-spacing:1.6px;text-transform:uppercase}
.pname{font-family:var(--font-display);font-weight:600;font-size:20px;color:var(--navy);line-height:1.15}
.pdesc{font-size:12px;color:var(--muted);flex:1;line-height:1.5;font-weight:400}
.pprice{font-weight:700;font-size:21px;color:var(--navy);display:flex;align-items:baseline;gap:6px;margin-top:2px}
.pprice::before{content:"";display:inline-block;width:14px;height:2px;background:var(--gold);align-self:center}
.pprice small{font-weight:500;color:var(--muted);font-size:11px;font-family:var(--font-ui)}
.addrow{display:flex;gap:7px;align-items:center;margin-top:8px}
.addrow input,.addrow select{border:1px solid var(--line);border-radius:10px;padding:9px 10px;font-size:12.5px;background:var(--soft);color:var(--ink);font-family:var(--font-ui)}
.addrow input:focus,.addrow select:focus{outline:none;border-color:var(--teal)}
.addrow .qty{width:62px;text-align:center}
.addrow select{flex:1;min-width:0}

/* ===== Botones ===== */
.btn{border:none;border-radius:10px;padding:9px 14px;font-family:var(--font-ui);font-weight:600;font-size:12.5px;cursor:pointer;letter-spacing:.3px;transition:.15s}
.btn-add{background:var(--navy);color:#fff;white-space:nowrap}
.btn-add:hover{background:var(--teal)}
.btn-primary{background:linear-gradient(120deg,var(--navy),var(--teal-deep));color:#fff;width:100%;padding:14px;font-size:13.5px;letter-spacing:.5px;border-radius:12px}
.btn-primary:hover{filter:brightness(1.08)}
.btn-primary:disabled{opacity:.45;cursor:not-allowed}
.btn-ghost{background:#fff;border:1px solid var(--line);color:var(--muted)}

/* ===== Carrito ===== */
.cart-wrap{display:grid;grid-template-columns:1fr 380px;gap:24px;align-items:start}
@media(max-width:860px){.cart-wrap{grid-template-columns:1fr}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:24px;box-shadow:var(--shadow)}
.card h3{margin:0 0 16px;font-size:1.25rem;color:var(--navy)}
.cline{display:flex;align-items:center;gap:12px;padding:13px 0;border-bottom:1px solid var(--line)}
.cline .nm{flex:1}.cline .nm b{font-size:14.5px;font-weight:600;color:var(--navy)}.cline .nm small{display:block;color:var(--muted);font-size:11.5px;margin-top:2px}
.cline input{width:64px;text-align:center;border:1px solid var(--line);border-radius:9px;padding:7px;font-size:12.5px;background:var(--soft)}
.cline .ss{width:96px;text-align:right;font-weight:700;color:var(--navy)}
.cline .rm{border:none;background:none;color:var(--red);cursor:pointer;font-size:16px}
.totrow{display:flex;justify-content:space-between;align-items:baseline;font-weight:700;font-size:16px;color:var(--navy);margin-top:18px;padding-top:16px;border-top:2px solid var(--line)}
.totrow .v{font-family:var(--font-display);font-size:26px;color:var(--navy)}
.minwarn{margin-top:10px;font-size:12px;padding:10px 12px;border-radius:10px;background:#fbf3e2;border:1px solid var(--gold-soft);color:#8a6a1f}
.field{margin-bottom:13px}
.field label{display:block;font-size:11px;color:var(--muted);font-weight:600;margin-bottom:5px;letter-spacing:.5px;text-transform:uppercase}
.field input,.field textarea{width:100%;border:1px solid var(--line);border-radius:11px;padding:11px 13px;font-size:13px;background:var(--soft);color:var(--ink);font-family:var(--font-ui)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--teal);background:#fff}
.empty{text-align:center;color:var(--muted);padding:70px 20px}
.empty .big{font-size:58px}
.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(40px);background:var(--navy);color:#fff;
  padding:13px 22px;border-radius:999px;font-weight:600;font-size:13px;opacity:0;transition:.3s;z-index:50;box-shadow:0 14px 34px rgba(14,42,71,.35)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast::before{content:"";display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--gold);margin-right:9px;vertical-align:middle}
.okbox{text-align:center;padding:50px 20px}
.okbox .chk{font-size:62px}
.okbox .ped{font-family:var(--font-display);font-size:2rem;color:var(--navy);font-weight:700;margin:10px 0}

/* ===== Marca / CTAs ===== */
.brand{display:flex;align-items:center}
.brand-logo{height:46px;width:auto;display:block}
.hide-sm{display:inline}
@media(max-width:640px){.hide-sm{display:none}}
.ig-btn,.wa-btn{display:flex;align-items:center;gap:7px;border-radius:999px;padding:8px 14px;font-family:var(--font-ui);font-weight:600;font-size:12.5px;letter-spacing:.3px;border:1px solid var(--line);background:#fff;color:var(--navy);transition:.15s}
.ig-btn:hover{border-color:#d62976;color:#d62976}
.wa-btn{background:#25d366;border-color:#25d366;color:#fff}
.wa-btn:hover{filter:brightness(1.06)}

/* ===== Footer ===== */
.site-foot{border-top:1px solid var(--line);margin-top:30px;background:#fff}
.foot-brand{max-width:1200px;margin:0 auto;padding:26px 30px 6px;display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.foot-logo{height:40px;width:auto}
.foot-links{display:flex;gap:20px;flex-wrap:wrap;align-items:center}
.foot-links a,.foot-links span{color:var(--muted);font-size:12.5px;font-weight:600}
.foot-links a:hover{color:var(--teal)}
.foot-credit{text-align:center;color:var(--muted);font-size:11px;padding:14px;letter-spacing:.4px}
.foot-credit span{color:var(--navy);font-weight:600}

.optin{display:flex;gap:8px;align-items:center;font-size:12.5px;color:var(--muted);margin:2px 0 12px;cursor:pointer}
.optin input{width:auto}

/* ===== Asistente / FAQ ===== */
.asistente{position:fixed;right:22px;bottom:22px;z-index:60;display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.asis-fab{width:56px;height:56px;border-radius:50%;border:none;background:linear-gradient(135deg,var(--navy),var(--teal));color:#fff;font-size:23px;cursor:pointer;box-shadow:0 10px 26px rgba(14,42,71,.35)}
.asis-fab:hover{filter:brightness(1.1)}
.asis-panel{width:330px;max-width:88vw;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 22px 54px rgba(14,42,71,.28);overflow:hidden}
.asis-head{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:linear-gradient(120deg,var(--navy),var(--teal));color:#fff}
.asis-head strong{font-family:var(--font-display);font-size:1.05rem}
.asis-x{background:none;border:none;color:#fff;font-size:16px;cursor:pointer}
.asis-body{padding:6px 14px;max-height:52vh;overflow:auto}
.asis-body details{border-bottom:1px solid var(--line);padding:9px 0}
.asis-body summary{cursor:pointer;font-weight:600;color:var(--navy);font-size:13.5px;list-style:none}
.asis-body summary::-webkit-details-marker{display:none}
.asis-body summary::before{content:"+ ";color:var(--teal);font-weight:700}
.asis-body details[open] summary::before{content:"– "}
.asis-body p{margin:8px 0 2px;font-size:12.5px;color:var(--muted);line-height:1.55}
.asis-wa{display:block;text-align:center;margin:8px 14px 16px;background:#25d366;color:#fff;border-radius:10px;padding:11px;font-weight:700;font-size:13px}
.asis-wa:hover{filter:brightness(1.06)}

/* ===== Blazor base ===== */
.valid.modified:not([type=checkbox]){outline:1px solid #26b050}
.invalid{outline:1px solid #e50000}
.validation-message{color:#e50000}
#blazor-error-ui{background:#b32121;color:#fff;bottom:0;display:none;left:0;padding:.7rem 1.2rem;position:fixed;width:100%;z-index:1000}
#blazor-error-ui .dismiss{cursor:pointer;position:absolute;right:.6rem;top:.4rem}
.blazor-error-boundary{background:#b32121;padding:1rem;color:#fff}
