/* BLR — Black Label Research | Shared stylesheet (all pages) */
:root{
  --gold-dark:#794E18;
  --gold-core:#7D5119;
  --gold-mid:#8B5C1E;
  --gold-light:#E4B35A;
  --gold-grad:linear-gradient(135deg,#794E18 0%,#B07E2E 45%,#E4B35A 70%,#8B5C1E 100%);
  --ink:#1A1A1A;
  --cream:#F7F4EF;
  --line:rgba(26,26,26,.10);
  --sans:'Montserrat',system-ui,sans-serif;
  --serif:'Cormorant Garamond',Georgia,serif;
  --body:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:#fff;line-height:1.6;-webkit-font-smoothing:antialiased}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.gold-text{background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* utility bar */
.utility{background:var(--ink);color:#e9e4da;font-family:var(--sans);font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.utility .wrap{display:flex;justify-content:center;gap:26px;padding:9px 28px;flex-wrap:wrap;text-align:center}
.utility span{opacity:.85}

/* nav */
header.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;padding:14px 28px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand img,.brand svg{width:38px;height:38px;display:block}
.brand .bwrap{font-family:var(--sans);line-height:1}
.brand .bwrap b{font-weight:800;font-size:20px;letter-spacing:.12em}
.brand .bwrap small{display:block;font-size:8px;letter-spacing:.3em;color:#8a8a8a;margin-top:2px}
nav ul{list-style:none;display:flex;gap:30px}
nav a{font-family:var(--sans);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);text-decoration:none;font-weight:600;opacity:.75;transition:opacity .2s}
nav a:hover,nav a:focus{opacity:1}
nav a.active{opacity:1;border-bottom:2px solid var(--gold-core);padding-bottom:2px}
.navtoggle{display:none;background:none;border:0;font-size:24px;color:var(--ink);cursor:pointer}

/* hero */
.hero{position:relative;text-align:center;padding:84px 28px 92px;background:
  radial-gradient(120% 80% at 50% 0%, #fff 0%, #faf7f2 55%, #f3ede3 100%)}
.hero.hero-sm{padding:60px 28px 52px}
.hero .hexmark{width:60px;height:60px;margin:0 auto 26px;display:block}
.hero .heroimg{max-width:380px;width:80%;height:auto;margin:0 auto 8px;display:block}
.hero .wordmark{font-family:var(--sans);font-weight:800;font-size:clamp(52px,11vw,120px);letter-spacing:.04em;line-height:.9}
.hero .sub-word{font-family:var(--sans);font-weight:600;font-size:clamp(11px,2.4vw,15px);letter-spacing:.42em;color:var(--ink);margin-top:10px}
.tagline{display:inline-block;margin:30px 0 0;font-family:var(--sans);font-weight:700;font-size:13px;letter-spacing:.28em;color:var(--gold-core);border:1px solid var(--line);padding:11px 22px}
.hero h1{font-family:var(--sans);font-weight:600;font-size:clamp(26px,5vw,44px);letter-spacing:.14em;text-transform:uppercase;margin:40px 0 6px}
.hero.hero-sm h1{margin-top:26px}
.rule{width:64px;height:2px;background:var(--gold-grad);margin:14px auto}
.hero p.lead{font-family:var(--body);max-width:520px;margin:0 auto;color:#4a4a4a;font-size:16px}
.cta-row{display:flex;gap:16px;justify-content:center;margin-top:34px;flex-wrap:wrap}
.btn{font-family:var(--sans);font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;padding:15px 30px;text-decoration:none;cursor:pointer;border:1px solid var(--gold-core);transition:.22s;display:inline-block}
.btn-primary{background:var(--gold-grad);color:#fff;border-color:transparent}
.btn-primary:hover{filter:brightness(1.08)}
.btn-ghost{background:transparent;color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-sm{font-size:10.5px;padding:10px 18px}
.btn[aria-disabled="true"]{cursor:not-allowed}

/* demo notice */
.demo-note{background:#fbf6ec;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.demo-note .wrap{display:flex;align-items:center;gap:14px;justify-content:center;padding:14px 28px;text-align:center;flex-wrap:wrap}
.demo-note .dot{width:8px;height:8px;border-radius:50%;background:var(--gold-core);flex:0 0 auto}
.demo-note p{font-family:var(--sans);font-size:12px;letter-spacing:.06em;color:#6a5a3a}

/* compliance strip */
.compliance{padding:38px 28px;background:#fff;border-bottom:1px solid var(--line)}
.compliance .wrap{display:flex;align-items:center;gap:34px;flex-wrap:wrap;justify-content:center}
.compliance .lead-txt{max-width:360px}
.compliance .lead-txt b{font-family:var(--sans);font-size:13px;letter-spacing:.1em;text-transform:uppercase;display:block;margin-bottom:6px}
.compliance .lead-txt span{font-size:13px;color:#666}
.badges{display:flex;gap:26px;flex-wrap:wrap;justify-content:center}
.badge{text-align:center;width:120px}
.badge .ic{width:42px;height:42px;border:1.5px solid var(--gold-core);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 8px;color:var(--gold-core)}
.badge small{font-family:var(--sans);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:#555;line-height:1.5;display:block}

/* why choose */
.why{padding:78px 28px;background:var(--cream)}
.section-head{text-align:center;margin-bottom:52px}
.section-head h2{font-family:var(--sans);font-weight:700;font-size:clamp(22px,4vw,32px);letter-spacing:.12em;text-transform:uppercase}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--line)}
.card{background:var(--cream);padding:34px 26px;text-align:center;transition:background .25s}
.card:hover{background:#fff}
.card .ic{width:52px;height:52px;color:var(--gold-core);margin:0 auto 18px}
.card h3{font-family:var(--sans);font-weight:700;font-size:13px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px}
.card p{font-size:13.5px;color:#5a5a5a;max-width:240px;margin:0 auto}

/* shipping band */
.ship{background:var(--ink);color:#efe9dd;padding:70px 28px;position:relative;overflow:hidden}
.ship .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.ship h2{font-family:var(--sans);font-weight:700;font-size:26px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-light);margin-bottom:18px}
.ship p{color:#c9c2b4;max-width:440px;margin-bottom:14px;font-size:15px}
.ship .feats{display:flex;gap:28px;margin-top:26px;flex-wrap:wrap}
.ship .feat{text-align:center}
.ship .feat .ic{width:34px;height:34px;color:var(--gold-light);margin:0 auto 8px}
.ship .feat small{font-family:var(--sans);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:#b8b0a0}
.ship .mapart{font-family:var(--serif);font-size:120px;text-align:center;line-height:1;color:var(--gold-mid);opacity:.4;user-select:none}

/* trust / contact band (home) */
.trust{padding:76px 28px;text-align:center;background:
  radial-gradient(120% 90% at 50% 100%, #faf7f2 0%, #fff 70%)}
.trust .serif-hd{font-family:var(--serif);font-size:clamp(30px,5vw,46px);font-weight:600;letter-spacing:.02em}
.trust p{max-width:460px;margin:14px auto 30px;color:#555}
.contact-cards{display:flex;gap:18px;justify-content:center;flex-wrap:wrap}
.ccard{border:1px solid var(--line);padding:20px 26px;min-width:230px;text-align:left;display:flex;gap:14px;align-items:center}
.ccard .ic{width:34px;height:34px;color:var(--gold-core);flex:0 0 auto}
.ccard b{font-family:var(--sans);font-size:11px;letter-spacing:.14em;text-transform:uppercase;display:block;color:#888}
.ccard span{font-size:14px}

/* footer */
footer{background:var(--ink);color:#b9b2a4;padding:52px 28px 30px;font-size:13px}
footer .wrap{display:grid;grid-template-columns:1.4fr 1fr 1.6fr;gap:36px}
footer .fbrand .wordmark{font-family:var(--sans);font-weight:800;font-size:30px;letter-spacing:.08em}
footer .fbrand small{display:block;font-family:var(--sans);font-size:8px;letter-spacing:.34em;color:#8a8378;margin-top:2px}
footer h4{font-family:var(--sans);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#e9e4da;margin-bottom:14px}
footer ul{list-style:none}
footer ul li{margin-bottom:8px}
footer a{color:#b9b2a4;text-decoration:none}
footer a:hover{color:var(--gold-light)}
footer .disclaimer{font-size:12px;line-height:1.7;color:#8a8378}
.footbar{border-top:1px solid rgba(255,255,255,.1);margin-top:36px;padding-top:20px;text-align:center;font-size:11px;letter-spacing:.1em;color:#7d7568;font-family:var(--sans);text-transform:uppercase}

/* reveal */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}

/* ===================== Products page ===================== */
.products-grid{padding:70px 28px;background:#fff}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.pcard{border:1px solid var(--line);background:var(--cream);display:flex;flex-direction:column;transition:box-shadow .25s,transform .25s}
.pcard:hover{box-shadow:0 14px 32px rgba(26,26,26,.08);transform:translateY(-3px)}
.pcard .pmedia{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#faf7f2,#f0e9dc);border-bottom:1px solid var(--line)}
.pcard .pmedia svg{width:60px;height:60px;color:var(--gold-core);opacity:.85}
.pcard .pbody{padding:24px 22px 26px;display:flex;flex-direction:column;gap:8px;flex:1}
.pcard .pname{font-family:var(--sans);font-weight:700;font-size:14.5px;letter-spacing:.06em;text-transform:uppercase}
.pcard .pconc{font-family:var(--sans);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-core)}
.pcard .pdesc{font-size:13.5px;color:#5a5a5a;flex:1}
.pcard .pfoot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:10px;padding-top:14px;border-top:1px solid var(--line)}
.pcard .pprice{font-family:var(--sans);font-weight:700;font-size:16px;white-space:nowrap}
.pcard .pprice small{display:block;font-size:8.5px;letter-spacing:.08em;color:#999;font-weight:500;text-transform:uppercase}

/* ===================== About page ===================== */
.about-story{padding:78px 28px;background:#fff}
.about-story .wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about-story .simg{display:flex;align-items:center;justify-content:center;background:var(--cream);border:1px solid var(--line);padding:40px}
.about-story .simg img{width:100%;max-width:280px;height:auto;display:block}
.about-story h2{font-family:var(--sans);font-weight:700;font-size:clamp(20px,3.4vw,28px);letter-spacing:.1em;text-transform:uppercase;margin-bottom:18px}
.about-story p{color:#4a4a4a;margin-bottom:14px;font-size:15px}
.philosophy{padding:78px 28px;background:var(--cream)}
.phil-list{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:var(--line);margin-top:40px}
.phil-item{background:var(--cream);padding:26px 28px;display:flex;gap:16px;align-items:flex-start}
.phil-item .num{font-family:var(--serif);font-size:30px;color:var(--gold-core);flex:0 0 auto;line-height:1}
.phil-item b{display:block;font-family:var(--sans);font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px}
.phil-item span{font-size:13.5px;color:#5a5a5a}
.about-disclaimer{padding:56px 28px;text-align:center;background:#fff;border-top:1px solid var(--line)}
.about-disclaimer .wrap{max-width:640px}
.about-disclaimer p{font-size:12.5px;color:#777;line-height:1.8}

/* ===================== FAQ page ===================== */
.faq-section{padding:78px 28px;background:#fff}
.faq-list{max-width:760px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;background:none;border:0;padding:22px 4px;display:flex;justify-content:space-between;align-items:center;gap:20px;cursor:pointer;font-family:var(--sans);font-weight:600;font-size:14px;letter-spacing:.03em;color:var(--ink)}
.faq-q .plus{width:20px;height:20px;flex:0 0 auto;position:relative}
.faq-q .plus::before,.faq-q .plus::after{content:'';position:absolute;background:var(--gold-core);top:50%;left:50%;transform:translate(-50%,-50%)}
.faq-q .plus::before{width:14px;height:2px}
.faq-q .plus::after{width:2px;height:14px;transition:transform .2s,opacity .2s}
.faq-item.open .faq-q .plus::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-a p{padding:0 4px 22px;color:#5a5a5a;font-size:13.5px;max-width:640px}
.faq-item.open .faq-a{max-height:320px}

/* ===================== Info page — research-use agreement ===================== */
.info-agree{display:grid;grid-template-columns:1.42fr 1fr;background:var(--cream)}
.ia-left{background:var(--cream);padding:60px 50px 54px}
.ia-right{background:var(--ink);color:#e9e4da;padding:60px 46px 54px}
.hexicon{display:block}
.ia-head{display:flex;align-items:center;gap:22px}
.ia-head .hexicon{width:78px;height:78px;flex:0 0 auto}
.ia-head h2{font-family:var(--sans);font-weight:800;font-size:clamp(26px,3.4vw,44px);line-height:1.02;letter-spacing:.005em;text-transform:uppercase;color:var(--ink)}
.ia-rule{width:72px;height:3px;background:var(--gold-grad);margin:20px 0 22px 100px}
.ia-lead{font-size:17px;line-height:1.55;color:#3a3a3a;max-width:620px;margin-bottom:42px}
.ia-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;margin-bottom:34px}
.ia-item{text-align:center}
.ia-item .hexicon{width:58px;height:58px;margin:0 auto 16px}
.ia-item h3{font-family:var(--sans);font-weight:700;font-size:12.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink);line-height:1.35;margin-bottom:10px}
.ia-item p{font-size:12.5px;line-height:1.55;color:#5a5a5a}
.ia-refuse{display:flex;align-items:center;gap:22px;border:1px solid var(--line);background:#fff;padding:22px 26px}
.ia-refuse .hexicon{width:48px;height:48px;flex:0 0 auto}
.ia-refuse p{font-size:13.5px;line-height:1.55;color:#4a4a4a}
.ia-right h2{font-family:var(--sans);font-weight:700;font-size:14px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-light);margin-bottom:30px}
.ia-list{display:flex;flex-direction:column;gap:24px}
.ia-litem{display:flex;gap:16px;align-items:flex-start}
.ia-litem .hexicon{width:46px;height:46px;flex:0 0 auto;margin-top:2px}
.ia-litem p{font-size:13.5px;line-height:1.55;color:#d3cdc1}
.ia-sign{margin-top:40px;text-align:right}
.ia-sign .ia-wordmark{font-family:var(--serif);font-style:italic;font-weight:600;font-size:44px;line-height:1;background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block}
.ia-sign small{display:block;font-family:var(--sans);font-size:9px;letter-spacing:.4em;color:#9a8f78;margin-top:4px}
@media(max-width:900px){
  .info-agree{grid-template-columns:1fr}
  .ia-left,.ia-right{padding:44px 28px}
  .ia-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:520px){
  .ia-grid{grid-template-columns:1fr}
  .ia-head{flex-direction:column;text-align:center;gap:14px}
  .ia-head h1{font-size:30px}
  .ia-rule{margin:16px auto 22px}
}

/* ===================== Contact page ===================== */
.contact-section{padding:78px 28px;background:#fff}
.contact-section .wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.form-visual{border:1px solid var(--line);padding:36px;background:var(--cream)}
.form-visual .frow{margin-bottom:18px}
.form-visual label{display:block;font-family:var(--sans);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:#666;margin-bottom:6px}
.form-visual input,.form-visual select,.form-visual textarea{width:100%;padding:12px 14px;border:1px solid var(--line);background:#fff;font-family:var(--body);font-size:13.5px;color:var(--ink)}
.form-visual textarea{resize:vertical;min-height:110px}
.form-note{font-size:11.5px;color:#8a8378;margin-top:14px;line-height:1.7}
.contact-info h2{font-family:var(--sans);font-weight:700;font-size:clamp(20px,3.4vw,26px);letter-spacing:.1em;text-transform:uppercase;margin-bottom:16px}
.contact-info>p{color:#4a4a4a;margin-bottom:26px;font-size:15px}
.contact-info .ccard{margin-bottom:14px;width:100%}

/* ===================== shared page banners ===================== */
.page-banner{padding:56px 28px;text-align:center;background:var(--cream);border-bottom:1px solid var(--line)}
.page-banner p{font-family:var(--sans);font-size:12px;letter-spacing:.06em;color:#6a5a3a;max-width:640px;margin:0 auto}

/* ===================== Catalog (categorised product list) ===================== */
.catalog{padding:70px 28px 24px;background:#fff}
.cat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
.cat-card{border:1px solid var(--line);background:var(--cream);padding:28px 28px 24px;display:flex;flex-direction:column;transition:box-shadow .25s,transform .25s}
.cat-card:hover{box-shadow:0 14px 32px rgba(26,26,26,.07);transform:translateY(-2px)}
.cat-head{display:flex;align-items:center;gap:14px;padding-bottom:16px;margin-bottom:6px;border-bottom:1px solid var(--line)}
.cat-head .ic{width:40px;height:40px;flex:0 0 auto;color:var(--gold-core)}
.cat-head h3{font-family:var(--sans);font-weight:700;font-size:15px;letter-spacing:.12em;text-transform:uppercase;line-height:1.2}
.cat-table{display:flex;flex-direction:column}
.cat-colhead{display:grid;grid-template-columns:1fr auto;gap:16px;padding:10px 0 8px}
.cat-colhead span{font-family:var(--sans);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:#a08a5e}
.cat-colhead span:last-child{text-align:right}
.cat-row{display:grid;grid-template-columns:1fr auto;gap:16px;padding:9px 0;border-top:1px solid var(--line);align-items:baseline}
.cat-row .cname{font-family:var(--sans);font-weight:600;font-size:12.5px;letter-spacing:.03em;text-transform:uppercase;color:var(--ink)}
.cat-row .cstr{font-size:12px;color:#6a6a6a;text-align:right;white-space:nowrap}
.cat-card .btn{margin-top:20px;align-self:flex-start}

/* trust badges strip */
.trust-badges{padding:14px 28px 70px;background:#fff}
.tb-inner{border:1px solid var(--line);background:var(--cream);display:grid;grid-template-columns:repeat(6,1fr)}
.tb-item{padding:26px 18px;text-align:center;border-right:1px solid var(--line)}
.tb-item:last-child{border-right:0}
.tb-item .ic{width:34px;height:34px;color:var(--gold-core);margin:0 auto 12px}
.tb-item b{display:block;font-family:var(--sans);font-size:11px;letter-spacing:.08em;text-transform:uppercase;line-height:1.4}
.tb-item small{display:block;font-size:10px;color:#8a7f6a;margin-top:4px;letter-spacing:.04em}

/* ===================== Order builder (products page) ===================== */
.order-page{padding:44px 28px 24px;background:#fff}
.order-layout{display:grid;grid-template-columns:1fr 340px;gap:34px;align-items:start}
.order-grid{grid-template-columns:repeat(3,1fr);gap:20px}
.order-grid .vcard{padding-bottom:18px}
.vcard.in-order{background:#fff;box-shadow:0 0 0 1.5px var(--gold-core) inset,0 12px 28px rgba(26,26,26,.08)}
.pprice-row{margin:0 0 12px}
.pprice-row .pprice{font-family:var(--sans);font-weight:700;font-size:17px}

/* quantity stepper */
.qty{display:flex;align-items:center;justify-content:center;gap:0;margin-top:auto}
.qty .qbtn{width:38px;height:38px;border:1px solid var(--gold-core);background:#fff;color:var(--gold-core);font-family:var(--sans);font-size:18px;font-weight:700;line-height:1;cursor:pointer;transition:.18s;display:flex;align-items:center;justify-content:center}
.qty .qbtn:hover{background:var(--gold-grad);color:#fff;border-color:transparent}
.qty .qinput{width:52px;height:38px;text-align:center;border:1px solid var(--line);border-left:0;border-right:0;font-family:var(--sans);font-size:15px;font-weight:600;color:var(--ink);background:#fff;-moz-appearance:textfield}
.qty .qinput::-webkit-outer-spin-button,.qty .qinput::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}

/* order summary panel */
.order-summary{position:sticky;top:88px}
.os-card{border:1px solid var(--line);background:var(--cream);padding:26px 24px}
.os-card h3{font-family:var(--sans);font-weight:700;font-size:14px;letter-spacing:.12em;text-transform:uppercase;padding-bottom:14px;border-bottom:1px solid var(--line);margin-bottom:14px}
.os-lines{min-height:40px}
.os-empty{font-size:12.5px;color:#8a8378;line-height:1.6}
.os-line{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:baseline;padding:7px 0;border-bottom:1px solid var(--line);font-size:12.5px}
.os-line .ol-qty{font-family:var(--sans);font-weight:700;color:var(--gold-core)}
.os-line .ol-name{color:#333}
.os-line .ol-sum{font-family:var(--sans);font-weight:600;white-space:nowrap}
.os-srow{display:flex;justify-content:space-between;align-items:baseline;margin-top:9px}
.os-srow span{font-family:var(--sans);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:#666}
.os-srow b{font-family:var(--sans);font-weight:600;font-size:13px}
.os-srow b.free{color:#3a6b2e}
.os-total{display:flex;justify-content:space-between;align-items:baseline;margin-top:12px;padding-top:12px;border-top:2px solid var(--gold-core)}
.os-total span{font-family:var(--sans);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#666}
.os-total b{font-family:var(--sans);font-size:22px;font-weight:800}
.os-shipnote{font-size:10.5px;color:#8a8378;margin-top:6px}
.os-fields{margin-top:20px}
.os-fields .frow{margin-bottom:14px}
.os-fields label{display:block;font-family:var(--sans);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:#666;margin-bottom:6px}
.os-fields label .opt{color:#a89e8a;letter-spacing:.04em}
.os-fields input,.os-fields textarea{width:100%;padding:11px 13px;border:1px solid var(--line);background:#fff;font-family:var(--body);font-size:13.5px;color:var(--ink)}
.os-fields textarea{resize:vertical;min-height:70px}
.os-check{display:flex;gap:10px;align-items:flex-start;margin-top:4px;cursor:pointer}
.os-check input{flex:0 0 auto;width:16px;height:16px;margin-top:2px;accent-color:var(--gold-core)}
.os-check span{font-size:11.5px;line-height:1.55;color:#5a5a5a;text-transform:none;letter-spacing:0}
.os-submit{width:100%;margin-top:18px;text-align:center}
.os-wa{width:100%;margin-top:10px;text-align:center}
.os-status{font-size:12px;line-height:1.5;margin-top:12px;min-height:1px}
.os-status--ok{color:#3a6b2e}
.os-status--err{color:#a23b2e}
.os-note{font-size:10.5px;color:#8a8378;margin-top:12px;line-height:1.6}

@media(max-width:960px){
  .order-layout{grid-template-columns:1fr}
  .order-summary{position:static;order:2}
  .order-products{order:1}
  .order-grid{grid-template-columns:repeat(3,1fr)}
}

/* ===================== Orders dashboard (internal) ===================== */
.orders-login{min-height:60vh;display:flex;align-items:center;justify-content:center;padding:60px 28px;background:var(--cream)}
.ol-card{width:100%;max-width:380px;border:1px solid var(--line);background:#fff;padding:34px 30px;text-align:center}
.ol-card h1{font-family:var(--sans);font-weight:700;font-size:20px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px}
.ol-card p{font-size:13px;color:#6a6a6a;margin-bottom:20px}
.ol-card .frow{text-align:left;margin-bottom:16px}
.ol-card label{display:block;font-family:var(--sans);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:#666;margin-bottom:6px}
.ol-card input{width:100%;padding:12px 14px;border:1px solid var(--line);font-family:var(--body);font-size:14px}
.ol-card .btn{width:100%}

.orders-dash{padding:34px 28px 70px;background:#fff;min-height:60vh}
.od-head{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:18px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.od-head h1{font-family:var(--sans);font-weight:700;font-size:22px;letter-spacing:.1em;text-transform:uppercase}
.od-count{font-family:var(--sans);font-size:11px;letter-spacing:.06em;color:#a08a5e;text-transform:none;font-weight:500;margin-left:8px}
.od-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.od-filter{display:flex;border:1px solid var(--line)}
.od-tab{background:#fff;border:0;border-right:1px solid var(--line);padding:9px 14px;font-family:var(--sans);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;color:#777;cursor:pointer}
.od-tab:last-child{border-right:0}
.od-tab.active{background:var(--gold-grad);color:#fff}
.od-list{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.od-empty{color:#8a8378;font-size:14px;padding:20px 0}
.od-card{border:1px solid var(--line);background:var(--cream);display:flex;flex-direction:column}
.od-card.done{opacity:.72}
.od-top{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 18px;border-bottom:1px solid var(--line)}
.od-badge{font-family:var(--sans);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;padding:4px 9px;margin-right:10px}
.od-badge.s-new{background:#fbf1dc;color:#8B5C1E}
.od-badge.s-sent{background:#e3edf7;color:#2c5f8a}
.od-badge.s-paid{background:#e5efe2;color:#3a6b2e}
.od-badge.s-done{background:#e8e6e2;color:#555}
.od-date{font-size:12px;color:#6a6a6a}
.od-phone{margin-top:6px}
.od-phone .od-num{font-family:var(--sans);font-weight:600;font-size:13px;color:var(--ink)}
.od-phone-acts{display:inline-flex;gap:6px;margin-left:8px}
.od-phone-acts a{font-family:var(--sans);font-size:9.5px;letter-spacing:.06em;text-transform:uppercase;font-weight:600;text-decoration:none;color:var(--gold-core);border:1px solid var(--line);padding:3px 7px;border-radius:2px}
.od-phone-acts a:hover{background:var(--gold-grad);color:#fff;border-color:transparent}
.od-status-lbl{font-family:var(--sans);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:#777;display:flex;align-items:center;gap:8px}
.od-status{font-family:var(--sans);font-size:12px;font-weight:600;color:var(--ink);padding:7px 10px;border:1px solid var(--gold-core);background:#fff;cursor:pointer}
.od-total{font-family:var(--sans);font-weight:800;font-size:18px}
.od-body{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:16px 18px}
.od-cust{font-size:13px;line-height:1.6}
.od-name{font-family:var(--sans);font-weight:700;font-size:13.5px;letter-spacing:.03em;margin-bottom:4px}
.od-cust a{color:var(--gold-core);text-decoration:none}
.od-cust a:hover{text-decoration:underline}
.od-notes{margin-top:8px;font-size:12.5px;color:#5a5a5a}
.od-items{width:100%;border-collapse:collapse;font-size:12.5px}
.od-items td{padding:3px 4px;border-bottom:1px solid var(--line)}
.od-items td.r{text-align:right;white-space:nowrap}
.od-items tfoot td{border-bottom:0;color:#6a6a6a;padding-top:6px}
.od-items tfoot tr.tot td{font-family:var(--sans);font-weight:700;color:var(--ink);font-size:13.5px}
.od-actions{display:flex;gap:10px;padding:14px 18px;border-top:1px solid var(--line);margin-top:auto}
.od-actions .od-del{margin-left:auto;color:#a23b2e;border-color:#e2c3bd}
.od-actions .od-del:hover{background:#a23b2e;color:#fff;border-color:#a23b2e}
@media(max-width:860px){
  .od-list{grid-template-columns:1fr}
}
@media(max-width:520px){
  .od-body{grid-template-columns:1fr}
}

/* ===================== Vial product cards ===================== */
.catalog-cards{padding:56px 28px 24px;background:#fff}
.cat-block{margin-bottom:8px}
.cat-title{display:flex;align-items:center;gap:14px;margin:40px 0 24px}
.cat-title .ic{width:34px;height:34px;flex:0 0 auto;color:var(--gold-core)}
.cat-title h2{font-family:var(--sans);font-weight:700;font-size:16px;letter-spacing:.14em;text-transform:uppercase;line-height:1.2}
.cat-title .cnt{margin-left:auto;font-family:var(--sans);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:#a08a5e;white-space:nowrap}
.vgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.vcard{border:1px solid var(--line);background:var(--cream);text-align:center;display:flex;flex-direction:column;padding:20px 16px 22px;transition:box-shadow .25s,transform .25s}
.vcard:hover{box-shadow:0 16px 32px rgba(26,26,26,.09);transform:translateY(-3px);background:#fff}
.vcard .vmedia{background:#fff;border:1px solid var(--line);padding:14px 0 10px;margin-bottom:16px;min-height:184px;display:flex;align-items:center;justify-content:center}
.vcard .vial{width:78px;height:auto;display:block;margin:0 auto;filter:drop-shadow(0 8px 12px rgba(26,26,26,.10))}
.vcard .vphoto{display:block;max-width:100%;max-height:200px;width:auto;margin:0 auto;object-fit:contain;filter:drop-shadow(0 8px 14px rgba(26,26,26,.12))}
.vcard .pname{font-family:var(--sans);font-weight:700;font-size:12.5px;letter-spacing:.03em;text-transform:uppercase;line-height:1.35;min-height:34px;display:flex;align-items:center;justify-content:center}
.vcard .pconc{font-family:var(--sans);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-core);margin:5px 0 12px}
.vcard .pdesc{font-size:12px;line-height:1.55;color:#5a5a5a;margin:0 0 16px}
.vcard .btn{align-self:center;margin-top:auto}

@media(max-width:860px){
  .grid{grid-template-columns:repeat(2,1fr)}
  .pgrid{grid-template-columns:repeat(2,1fr)}
  .ship .wrap{grid-template-columns:1fr}
  .ship .mapart{display:none}
  .about-story .wrap{grid-template-columns:1fr}
  .phil-list{grid-template-columns:1fr}
  .contact-section .wrap{grid-template-columns:1fr}
  .cat-grid{grid-template-columns:1fr}
  .vgrid{grid-template-columns:repeat(2,1fr)}
  .order-grid{grid-template-columns:repeat(2,1fr)}
  .tb-inner{grid-template-columns:repeat(3,1fr)}
  .tb-item:nth-child(3){border-right:0}
  .tb-item:nth-child(-n+3){border-bottom:1px solid var(--line)}
  footer .wrap{grid-template-columns:1fr}
  nav ul{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;gap:0;border-bottom:1px solid var(--line);padding:8px 0}
  nav ul.open{display:flex}
  nav ul li{padding:12px 28px;border-top:1px solid var(--line)}
  .navtoggle{display:block}
}
@media(max-width:520px){
  .grid{grid-template-columns:1fr}
  .pgrid{grid-template-columns:1fr}
  .vgrid{grid-template-columns:repeat(2,1fr)}
  .order-grid{grid-template-columns:repeat(2,1fr)}
  .tb-inner{grid-template-columns:repeat(2,1fr)}
  .tb-item{border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
  .tb-item:nth-child(2n){border-right:0}
}
