/* lumex.uz — flattened stylesheet (tokens + site). Auto-generated. */
@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@400;500;600;700;800;900&family=Archivo:ital,wght@0,400..900;1,400..900&family=Hanken+Grotesk:wght@400;500;600;700&display=swap');

/* ===== TOKENS ===== */
/* ============================================================
   LUMEX — COLOR TOKENS
   Brand direction: deep professional green + warm cream,
   with a single warm "light" accent (the glow of yorug'lik).
   No red / orange / aggressive hues. Not corporate blue.
   ============================================================ */

:root {
  /* --- Green (primary brand family) ------------------------ */
  /* Anchored to the official Lumex logo green: #236F53 = green-800 */
  --green-950: #0C2C20; /* deepest — shadows, footers          */
  --green-900: #164A37; /* darker field / depth                */
  --green-800: #236F53; /* PRIMARY brand green (official logo)  */
  --green-700: #2C8062; /* raised / hover (lighter)            */
  --green-600: #359072;
  --green-500: #4A9E81; /* mid — interactive on light          */
  --green-400: #6FB59B;
  --green-300: #97C9B4; /* muted sage — subtle accents/text    */
  --green-200: #C0DDD1;
  --green-100: #E2EFE8;

  /* --- Cream (light family / text on green) ---------------- */
  /* Anchored to the official logo text: #F2F1BC = cream-200 */
  --cream-50:  #FCFBEC;
  --cream-100: #F8F6D6; /* lightest paper                      */
  --cream-200: #F2F1BC; /* PRIMARY cream (official logo text)  */
  --cream-300: #E4E2A0;
  --cream-400: #D0CD80;

  /* --- Glow (warm light accent — use sparingly) ------------ */
  --glow-300: #F7E1A4;
  --glow-400: #F1CE76;
  --glow-500: #E9BE52; /* ACCENT — the light / highlight       */
  --glow-600: #D2A638;

  /* --- Warm neutrals --------------------------------------- */
  --ink-900: #14201B; /* warm green-black — text on light      */
  --stone-700: #41463F;
  --stone-500: #6E736A;
  --stone-400: #8E9389;
  --stone-300: #BFC2B8;
  --stone-200: #DEDFD6;
  --stone-100: #EEEEE6;
  --paper:     #FCFAF3; /* warm off-white page                 */
  --white:     #FFFFFF;

  /* --- Functional (kept muted, never aggressive) ----------- */
  --success: #357A5E; /* reuse brand green                     */
  --warning: #D2A638; /* warm amber, not orange                */
  --danger:  #9E4B3F; /* desaturated brick — quiet, not red    */
  --info:    #4F7A6B;

  /* ============================================================
     SEMANTIC ALIASES — reach for these in components
     ============================================================ */

  /* Brand */
  --brand-primary:       var(--green-800);
  --brand-primary-hover: var(--green-700);
  --brand-primary-press: var(--green-900);
  --brand-accent:        var(--glow-500);
  --brand-accent-hover:  var(--glow-400);
  --brand-on-primary:    var(--cream-200);
  --brand-on-accent:     var(--green-900);

  /* Surfaces — dark (the signature Lumex green field) */
  --surface-dark:        var(--green-800);
  --surface-dark-2:      var(--green-900);
  --surface-dark-raised: var(--green-700);

  /* Surfaces — light (paper) */
  --surface-page:        var(--paper);
  --surface-card:        var(--white);
  --surface-sunken:      var(--stone-100);

  /* Text — on dark surfaces */
  --text-on-dark:        var(--cream-200);
  --text-on-dark-muted:  var(--green-300);
  --text-on-dark-faint:  rgba(242, 241, 188, 0.55);

  /* Text — on light surfaces */
  --text-strong:         var(--ink-900);
  --text-body:           var(--stone-700);
  --text-muted:          var(--stone-500);

  /* Borders & lines */
  --border-on-dark:      rgba(242, 241, 188, 0.18);
  --border-on-dark-strong: rgba(242, 241, 188, 0.32);
  --border-on-light:     var(--stone-200);
  --border-on-light-strong: var(--stone-300);

  /* Focus ring */
  --focus-ring:          var(--glow-500);
}

/* ============================================================
   LUMEX — TYPOGRAPHY TOKENS
   Two families. Tight, confident display; calm, legible text.
   ============================================================ */

:root {
  /* --- Families ------------------------------------------- */
  --font-display: 'Archivo', 'Hanken Grotesk', system-ui, sans-serif;
  --font-text:    'Hanken Grotesk', system-ui, -apple-system, sans-serif;

  /* --- Weights -------------------------------------------- */
  --fw-regular:  400; /* @kind font */
  --fw-medium:   500; /* @kind font */
  --fw-semibold: 600; /* @kind font */
  --fw-bold:     700; /* @kind font */
  --fw-black:    800; /* @kind font */ /* headlines, signage, wordmark */

  /* --- Type scale (px-based, rem values) ------------------ */
  --text-2xs:  0.6875rem; /* 11 — legal, micro labels         */
  --text-xs:   0.75rem;   /* 12 — captions                    */
  --text-sm:   0.875rem;  /* 14 — secondary UI                */
  --text-base: 1rem;      /* 16 — body                        */
  --text-lg:   1.125rem;  /* 18 — lead body                   */
  --text-xl:   1.375rem;  /* 22 — small heading               */
  --text-2xl:  1.75rem;   /* 28 — heading                     */
  --text-3xl:  2.25rem;   /* 36 — section title               */
  --text-4xl:  3rem;      /* 48 — page title                  */
  --text-5xl:  4rem;      /* 64 — hero                        */
  --text-6xl:  5.5rem;    /* 88 — display / signage           */

  /* --- Line heights --------------------------------------- */
  --leading-tight:   1.05; /* display / wordmark              */
  --leading-snug:    1.2;  /* headings                        */
  --leading-normal:  1.5;  /* body                            */
  --leading-relaxed: 1.65; /* long-form                       */

  /* --- Letter spacing ------------------------------------- */
  --tracking-tight:  -0.02em; /* big display                  */
  --tracking-normal: 0;
  --tracking-wide:   0.04em;  /* small caps labels            */
  --tracking-wider:  0.14em;  /* TAGLINE / overlines (JUST LIGHTING) */
}

/* ============================================================
   LUMEX — SPACING, RADII, SHADOW, MOTION TOKENS
   8px base grid. Generous, calm spacing. Soft squared corners.
   ============================================================ */

:root {
  /* --- Spacing scale (8px base, 4px half-steps) ----------- */
  --space-0:  0;
  --space-1:  0.25rem; /* 4  */
  --space-2:  0.5rem;  /* 8  */
  --space-3:  0.75rem; /* 12 */
  --space-4:  1rem;    /* 16 */
  --space-5:  1.5rem;  /* 24 */
  --space-6:  2rem;    /* 32 */
  --space-7:  3rem;    /* 48 */
  --space-8:  4rem;    /* 64 */
  --space-9:  6rem;    /* 96 */
  --space-10: 8rem;    /* 128 */

  /* --- Radii (soft, squared — not pill-round) ------------- */
  --radius-xs:   3px;
  --radius-sm:   6px;
  --radius-md:   10px;  /* default cards, inputs, buttons     */
  --radius-lg:   16px;
  --radius-xl:   24px;
  --radius-full: 999px; /* avatars, dots, tag chips only      */

  /* --- Border widths -------------------------------------- */
  --border-thin:  1px;
  --border-med:   1.5px;
  --border-thick: 2px;

  /* --- Shadows (soft, warm-tinted, never harsh) ----------- */
  --shadow-xs: 0 1px 2px rgba(14, 42, 32, 0.06);
  --shadow-sm: 0 2px 6px rgba(14, 42, 32, 0.08);
  --shadow-md: 0 6px 18px rgba(14, 42, 32, 0.10);
  --shadow-lg: 0 16px 40px rgba(14, 42, 32, 0.14);
  /* Warm glow — for accent emphasis only (the "light") */
  --shadow-glow: 0 0 0 1px rgba(233, 190, 82, 0.35), 0 8px 28px rgba(233, 190, 82, 0.22);

  /* --- Motion --------------------------------------------- */
  --ease-out:   cubic-bezier(0.22, 0.61, 0.36, 1); /* @kind other */
  --ease-inout: cubic-bezier(0.65, 0.05, 0.36, 1); /* @kind other */
  --dur-fast:   120ms; /* @kind other */
  --dur-base:   200ms; /* @kind other */
  --dur-slow:   360ms; /* @kind other */

  /* --- Containers ----------------------------------------- */
  --container-sm:  640px;
  --container-md:  960px;
  --container-lg:  1200px;
}


/* ============================================================
   lumex.uz — shared site styles (Variant B · Light & airy,
   green as accent). Self-contained — tokens are above.
   ============================================================ */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: var(--font-text); background: var(--white); color: var(--text-strong); }
a { text-decoration: none; color: inherit; }
img { display: block; }
.wrap { max-width: 1180px; margin: 0 auto; padding: 0 40px; }
h1,h2,h3,h4 { font-family: var(--font-display); letter-spacing: -0.02em; margin: 0; }
.eyebrow { font-weight: 600; letter-spacing: 0.16em; font-size: 12px; text-transform: uppercase; color: var(--green-600); }

/* ---- Buttons ---- */
.btn { display: inline-flex; align-items: center; gap: 9px; font-family: var(--font-text); font-weight: 600; font-size: 15px; border-radius: var(--radius-md); padding: 13px 22px; cursor: pointer; border: 1.5px solid transparent; white-space: nowrap; transition: filter var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out); }
.btn:hover { filter: brightness(1.06); }
.btn:active { transform: translateY(1px); }
.btn-green { background: var(--green-800); color: var(--cream-200); }
.btn-accent { background: var(--glow-500); color: var(--green-900); }
.btn-ghost, .btn-outline-l { background: transparent; color: var(--green-800); border-color: var(--border-on-light-strong); }
.btn-outline-d { background: transparent; color: var(--cream-200); border-color: var(--border-on-dark-strong); }
.btn-sm { padding: 9px 16px; font-size: 14px; }
.ico { width: 18px; height: 18px; }

/* ---- Header — white, airy, sticky ---- */
header.site { position: sticky; top: 0; z-index: 40; background: rgba(255,255,255,0.86); backdrop-filter: blur(10px); border-bottom: 1px solid var(--border-on-light); }
.nav { height: 72px; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.logo { font-family: var(--font-display); font-weight: 800; font-size: 28px; letter-spacing: -0.03em; color: var(--green-800); }
.nav-links { display: flex; gap: 28px; }
.nav-links a { color: var(--text-body); font-size: 14px; font-weight: 500; transition: color var(--dur-fast) var(--ease-out); }
.nav-links a:hover, .nav-links a.active { color: var(--green-700); }
.nav-links a.active { font-weight: 600; }
.nav-right { display: flex; align-items: center; gap: 14px; }
.phone { display: inline-flex; align-items: center; gap: 8px; color: var(--text-body); font-weight: 600; font-size: 14px; white-space: nowrap; }
.phone .ico { color: var(--green-600); }
.lang { display: inline-flex; border: 1px solid var(--border-on-light-strong); border-radius: var(--radius-sm); overflow: hidden; }
.lang button { background: transparent; border: none; color: var(--text-muted); font-size: 12px; font-weight: 600; padding: 5px 9px; cursor: pointer; font-family: var(--font-text); transition: background var(--dur-fast) var(--ease-out); }
.lang button.on { background: var(--green-800); color: var(--cream-200); }
.burger { display: none; background: transparent; border: none; color: var(--green-800); cursor: pointer; }

/* ---- Sections ---- */
section.block { padding: 84px 0; }
.sec-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; margin-bottom: 40px; }
.sec-head .eyebrow { color: var(--green-600); }
.sec-head h2 { font-size: 40px; font-weight: 800; margin-top: 12px; }
.sec-head p { color: var(--text-muted); font-size: 17px; margin: 8px 0 0; }
.center { text-align: center; flex-direction: column; align-items: center; }
.tint { background: var(--surface-page); }

/* ---- Page hero (inner pages) — light gradient ---- */
.page-hero { background: linear-gradient(180deg, var(--green-100), var(--white)); color: var(--text-strong); position: relative; overflow: hidden; border-bottom: 1px solid var(--border-on-light); }
.page-hero .ring { position: absolute; right: -150px; top: -130px; opacity: 0.55; color: var(--green-200); }
.page-hero .ring circle { stroke: currentColor; }
.page-hero .wrap { position: relative; z-index: 2; padding: 56px 40px 60px; }
.page-hero .eyebrow { color: var(--green-600); }
.page-hero h1 { font-size: 52px; font-weight: 800; margin-top: 14px; line-height: 1.04; max-width: 18ch; }
.page-hero p { font-size: 18px; line-height: 1.55; color: var(--text-body); max-width: 560px; margin: 16px 0 0; }
.crumbs { font-size: 13px; color: var(--text-muted); display: flex; gap: 8px; align-items: center; }
.crumbs a { color: var(--text-muted); }
.crumbs a:hover { color: var(--green-700); }

/* ---- Category cards — light, thin border ---- */
.cat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.cat { background: var(--white); border: 1px solid var(--border-on-light); border-radius: var(--radius-lg); padding: 28px; transition: border-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out); cursor: pointer; }
.cat:hover { border-color: var(--green-300); box-shadow: var(--shadow-sm); transform: translateY(-2px); }
.cat .ic { width: 52px; height: 52px; border-radius: var(--radius-md); background: var(--green-100); display: flex; align-items: center; justify-content: center; color: var(--green-700); margin-bottom: 16px; }
.cat h3 { font-size: 20px; font-weight: 700; }
.cat .meta { display: flex; align-items: center; justify-content: space-between; margin-top: 12px; color: var(--text-muted); font-size: 14px; }
.cat .meta-soon { display: inline-block; margin-top: 12px; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .03em; color: var(--stone-500); background: var(--stone-100); padding: 3px 10px; border-radius: var(--radius-sm); }

/* ---- Product cards ---- */
.prod-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.prod { background: var(--white); border: 1px solid var(--border-on-light); border-radius: var(--radius-lg); overflow: hidden; transition: border-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out); }
.prod:hover { border-color: var(--green-300); box-shadow: var(--shadow-md); transform: translateY(-2px); }
.prod .ph { aspect-ratio: 3/4; background: var(--stone-100); position: relative; overflow: hidden; }
.prod .ph img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-slow) var(--ease-out); }
.prod:hover .ph img { transform: scale(1.04); }
.prod .tag { position: absolute; top: 12px; left: 12px; background: var(--glow-500); color: var(--green-900); font-size: 12px; font-weight: 700; padding: 4px 11px; border-radius: 999px; }
.prod .body { padding: 16px; }
.prod .body h3 { font-size: 16px; font-weight: 700; }
.prod .specs { font-size: 13px; color: var(--text-muted); margin: 6px 0 0; }
.prod .price { font-family: var(--font-display); font-weight: 800; font-size: 19px; color: var(--green-800); margin-top: 12px; }
.prod .price small { font-size: 13px; color: var(--text-muted); font-weight: 600; }

/* ---- Stats ---- */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.stat .ico-w { color: var(--green-600); }
.stat b { font-family: var(--font-display); font-weight: 800; font-size: 34px; color: var(--green-800); display: block; margin-top: 10px; }
.stat span { font-size: 14px; color: var(--text-muted); }

/* ---- CTA card — soft green panel ---- */
.cta-card { background: var(--green-100); border-radius: var(--radius-xl); padding: 48px; display: flex; gap: 40px; align-items: center; justify-content: space-between; flex-wrap: wrap; }
.cta-card h2 { color: var(--text-strong); font-size: 32px; font-weight: 800; }
.cta-card p { color: var(--text-body); font-size: 16px; margin: 12px 0 0; max-width: 420px; }
.cta-form { display: flex; gap: 12px; }
.field { height: 50px; border-radius: var(--radius-md); border: 1.5px solid var(--border-on-light-strong); padding: 0 16px; font-family: var(--font-text); font-size: 15px; background: var(--white); color: var(--text-strong); }
.field:focus { outline: none; border-color: var(--green-500); }

/* ---- Footer (green field) ---- */
footer.site { background: var(--green-800); color: var(--cream-200); padding: 52px 0 36px; }
footer.site .logo { color: var(--cream-200); }
.foot-top { display: flex; justify-content: space-between; gap: 32px; flex-wrap: wrap; padding-bottom: 30px; border-bottom: 1px solid var(--border-on-dark); }
.foot-contact { display: flex; flex-direction: column; gap: 8px; margin-top: 16px; color: var(--green-200); font-size: 14px; }
.foot-contact span { display: inline-flex; align-items: center; gap: 8px; }
.foot-nav { display: flex; gap: 40px; flex-wrap: wrap; }
.foot-nav a { color: var(--cream-200); font-size: 14px; opacity: 0.88; }
.foot-nav a:hover { opacity: 1; }
.foot-bottom { display: flex; justify-content: space-between; align-items: center; margin-top: 22px; font-size: 12px; color: var(--text-on-dark-faint); gap: 12px; flex-wrap: wrap; }
.foot-bottom .tl { letter-spacing: 0.16em; font-weight: 600; color: var(--green-300); }

/* ---- FAQ ---- */
.faq-list { max-width: 800px; margin: 0 auto; }
.faq { border: 1px solid var(--border-on-light); border-radius: var(--radius-md); margin-bottom: 12px; padding: 0 20px; }
.faq summary { list-style: none; cursor: pointer; padding: 20px 0; display: flex; align-items: center; justify-content: space-between; gap: 16px; font-family: var(--font-display); font-weight: 700; font-size: 18px; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary .pm { color: var(--green-600); font-size: 22px; transition: transform var(--dur-base) var(--ease-out); flex: none; }
.faq[open] summary .pm { transform: rotate(45deg); }
.faq p { margin: 0 0 20px; color: var(--text-body); font-size: 15px; line-height: 1.6; }

/* ============================================================
   Home page — Variant B specifics
   ============================================================ */
/* Hero — split, light */
.home-hero { padding: 80px 0 72px; }
.home-hero .grid { display: grid; grid-template-columns: 1.02fr 0.98fr; gap: 56px; align-items: center; }
.home-hero h1 { font-size: 60px; line-height: 1.02; font-weight: 800; margin-top: 18px; color: var(--text-strong); }
.home-hero h1 em { font-style: normal; color: var(--green-700); }
.home-hero p { font-size: 18px; line-height: 1.6; color: var(--text-body); margin: 22px 0 0; max-width: 480px; }
.home-hero .cta { display: flex; gap: 14px; margin-top: 32px; }
.hero-photo { position: relative; }
.hero-photo .main { width: 100%; aspect-ratio: 1/1; object-fit: cover; border-radius: var(--radius-xl); display: block; box-shadow: var(--shadow-lg); }
.hero-photo .chip { position: absolute; bottom: 22px; left: -22px; background: var(--white); border-radius: var(--radius-lg); padding: 14px 18px; box-shadow: var(--shadow-md); display: flex; align-items: center; gap: 12px; }
.hero-photo .chip .d { width: 40px; height: 40px; border-radius: 999px; background: var(--green-100); color: var(--green-700); display: flex; align-items: center; justify-content: center; }
.hero-photo .chip b { font-family: var(--font-display); font-weight: 800; font-size: 18px; display: block; }
.hero-photo .chip span { font-size: 12px; color: var(--text-muted); }

/* Trust strip */
.strip { border-top: 1px solid var(--border-on-light); border-bottom: 1px solid var(--border-on-light); }
.strip .wrap { display: flex; justify-content: space-between; gap: 24px; padding-top: 28px; padding-bottom: 28px; flex-wrap: wrap; }
.strip .it { display: flex; align-items: baseline; gap: 10px; }
.strip b { font-family: var(--font-display); font-weight: 800; font-size: 28px; color: var(--green-800); }
.strip span { font-size: 14px; color: var(--text-muted); }

/* About split */
.about-split { display: grid; grid-template-columns: 0.95fr 1.05fr; gap: 56px; align-items: center; }
.about-split .imgs { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.about-split .imgs img { width: 100%; aspect-ratio: 3/4; object-fit: cover; border-radius: var(--radius-lg); display: block; }
.about-split .imgs img:first-child { margin-top: 28px; }
.pts { display: flex; flex-direction: column; gap: 12px; margin-top: 24px; }
.pt { display: flex; gap: 12px; align-items: center; font-size: 16px; color: var(--text-body); }
.pt .c { width: 26px; height: 26px; border-radius: 999px; background: var(--green-100); color: var(--green-700); display: flex; align-items: center; justify-content: center; flex: none; }

/* Why — soft green tint, white cards */
.why { background: var(--green-100); }
.why-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.why .card { background: var(--white); border-radius: var(--radius-lg); padding: 26px; }
.why .wic { width: 48px; height: 48px; border-radius: var(--radius-md); background: var(--green-800); color: var(--cream-200); display: flex; align-items: center; justify-content: center; margin-bottom: 18px; }
.why h3 { font-size: 19px; font-weight: 700; }
.why .wd { font-size: 15px; line-height: 1.55; color: var(--text-body); margin: 10px 0 0; }

/* ---- Responsive ---- */
@media (max-width: 920px) {
  .nav-links, .phone { display: none; }
  .burger { display: inline-flex; }
  .cat-grid, .prod-grid, .stats, .why-grid { grid-template-columns: repeat(2, 1fr); }
  .home-hero .grid, .about-split { grid-template-columns: 1fr; }
  .page-hero h1, .home-hero h1 { font-size: 40px; }
}
@media (max-width: 560px) {
  .wrap { padding: 0 22px; }
  .cat-grid, .prod-grid, .why-grid { grid-template-columns: 1fr; }
}
