/* ============================================================
   NIČ NE RABIM. — Main stylesheet
   Editorial minimalism · warm, human · Warm Bone / Charcoal
   Signature: the 2pt strikethrough across NIČ.
   ============================================================ */

:root{
  /* Palette — 60 / 30 / 10 discipline */
  --bone:        #F5F2ED;
  --bone-soft:   #EFEBE3;
  --bone-line:   #E2DCD1;
  --charcoal:    #1A1A1A;
  --charcoal-2:  #2A2926;
  --sage:        #8A9A8A;
  --sage-deep:   #6E7E6E;
  --sand:        #D2C5B3;

  --ink:         #1A1A1A;
  --ink-60:      rgba(26,26,26,.60);
  --ink-42:      rgba(26,26,26,.42);
  --ink-28:      rgba(26,26,26,.28);

  --on-dark:     #EDE8DF;
  --on-dark-55:  rgba(237,232,223,.55);
  --on-dark-35:  rgba(237,232,223,.32);

  /* Type */
  --display: "Inter Tight", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --text:    "Inter", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --mono:    "Spline Sans Mono", "SF Mono", ui-monospace, Menlo, monospace;

  /* Rhythm */
  --gutter: clamp(22px, 6vw, 120px);
  --maxw: 1500px;
  --section-y: clamp(96px, 13vw, 220px);

  --line-w: 1.6px;
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--bone);
  color:var(--ink);
  font-family:var(--text);
  font-weight:400;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
/* WordPress admin bar offset */
body.admin-bar .nav{ top:var(--wp-admin--admin-bar--height, 32px); }
::selection{ background:var(--charcoal); color:var(--bone); }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; cursor:pointer; }

/* Film grain — warm texture, very low */
.grain{
  position:fixed; inset:0; z-index:90; pointer-events:none;
  opacity:.40; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.22'/></svg>");
}

/* ---------- Typographic primitives ---------- */
.eyebrow{
  font-family:var(--text);
  font-weight:500;
  font-size:clamp(10px, .78vw, 12px);
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--ink-42);
}
.eyebrow .dot-sep{ color:var(--ink-28); margin:0 .5em; }

.lede{
  font-family:var(--text);
  font-weight:300;
  font-size:clamp(16px, 1.5vw, 21px);
  line-height:1.6;
  letter-spacing:.005em;
  color:var(--ink-60);
}

/* The strikethrough NIČ — brand signature */
.nic{
  white-space:nowrap;
  text-decoration-line:line-through;
  text-decoration-color:currentColor;
  text-decoration-thickness:max(1.5px, .052em);
  text-decoration-skip-ink:none;
}
.nic--thick{ text-decoration-thickness:max(1.7px, .06em); }

/* the divider rule (animated on scroll) */
.rule{
  position:relative; height:var(--line-w); margin:0 var(--gutter);
  background:var(--ink-28);
  transform:scaleX(0); transform-origin:left center;
  transition:transform 1.1s cubic-bezier(.2,.7,.2,1);
}
.rule.in{ transform:scaleX(1); }

/* ===================================================================
   NAV
   =================================================================== */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:80;
  display:flex; align-items:center; justify-content:space-between;
  padding:clamp(16px,2vw,26px) var(--gutter);
  transition:background .4s ease, border-color .4s ease, padding .4s ease;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(245,242,237,.82);
  backdrop-filter:saturate(120%) blur(10px);
  -webkit-backdrop-filter:saturate(120%) blur(10px);
  border-bottom:1px solid var(--bone-line);
  padding-top:clamp(12px,1.4vw,16px); padding-bottom:clamp(12px,1.4vw,16px);
}
.brand{
  font-family:var(--display);
  font-weight:700; letter-spacing:-.02em;
  font-size:clamp(15px,1.15vw,17px);
  line-height:1; display:inline-flex; gap:.34em; align-items:baseline;
}
/* WordPress nav_menu list reset */
.nav-links ul, .nav-links li{ list-style:none; margin:0; padding:0; }
.nav-links{
  display:flex; gap:clamp(18px,2vw,34px);
  font-size:13px; letter-spacing:.04em; color:var(--ink-60);
}
/* When WP renders nav as <nav><ul><li><a>, flatten it */
.nav-links > ul{ display:flex; gap:clamp(18px,2vw,34px); }
.nav-links a{ position:relative; padding-bottom:3px; transition:color .25s; }
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:100%;
  background:var(--ink); transform:scaleX(0); transform-origin:right;
  transition:transform .3s cubic-bezier(.2,.7,.2,1);
}
.nav-links a:hover{ color:var(--ink); }
.nav-links a:hover::after{ transform:scaleX(1); transform-origin:left; }
.nav-cart{
  font-size:13px; letter-spacing:.04em; color:var(--ink-60);
  display:inline-flex; align-items:center; gap:.5em;
}
.nav-cart:hover{ color:var(--ink); }
.nav-menu-btn{ display:none; background:none; border:none; padding:6px; }
.nav-menu-btn span{ display:block; width:22px; height:1.5px; background:var(--ink); margin:5px 0; }

/* ===================================================================
   HERO
   =================================================================== */
.hero{
  padding:calc(var(--gutter) + 78px) var(--gutter) clamp(56px,8vw,110px);
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);
  gap:clamp(28px,5vw,80px);
  align-items:end;
  min-height:100svh;
}
.hero-copy{ align-self:center; max-width:760px; }
.hero h1{
  font-family:var(--display);
  font-weight:700;
  letter-spacing:-.035em;
  line-height:.9;
  margin:.5em 0 0;
  font-size:clamp(58px, 12.5vw, 184px);
  text-transform:uppercase;
}
.hero h1 .l1{ display:block; color:var(--ink); }
.hero h1 .l2{ display:block; }
.hero-manifesto{
  margin:clamp(26px,3vw,40px) 0 0;
  max-width:30ch;
}
.hero-actions{
  display:flex; align-items:center; gap:clamp(18px,2.4vw,34px);
  margin-top:clamp(30px,3.4vw,46px); flex-wrap:wrap;
}
.hero-img{ width:100%; height:100%; object-fit:cover; }
.btn{
  display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--text); font-weight:500; font-size:14px;
  letter-spacing:.02em;
  padding:15px 26px; border:1px solid var(--ink);
  background:var(--ink); color:var(--bone);
  transition:background .3s, color .3s, transform .3s;
}
.btn .arr{ transition:transform .3s cubic-bezier(.2,.7,.2,1); }
.btn:hover{ background:transparent; color:var(--ink); }
.btn:hover .arr{ transform:translateX(5px); }
.btn--ghost{
  background:transparent; color:var(--ink); border-color:transparent;
  padding:15px 4px;
  position:relative;
}
.btn--ghost::after{
  content:""; position:absolute; left:4px; right:4px; bottom:11px; height:1px;
  background:var(--ink-28); transition:background .3s;
}
.btn--ghost:hover::after{ background:var(--ink); }

.hero-figure{ align-self:stretch; min-height:clamp(420px,62vh,760px); }

/* ===================================================================
   PLACEHOLDERS — styled, warm, intentional
   =================================================================== */
.ph{
  position:relative; width:100%; height:100%;
  background-color:var(--bone-soft);
  background-image:repeating-linear-gradient(
    -45deg,
    var(--bone-soft) 0, var(--bone-soft) 11px,
    var(--bone-line) 11px, var(--bone-line) 12px);
  border:1px solid var(--bone-line);
  overflow:hidden;
  display:flex; flex-direction:column; justify-content:space-between;
}
.ph--sage{
  background-color:#cdd5cc;
  background-image:repeating-linear-gradient(-45deg,#cdd5cc 0,#cdd5cc 11px,#bcc6bb 11px,#bcc6bb 12px);
  border-color:#bcc6bb;
}
.ph--char{
  background-color:#23231f;
  background-image:repeating-linear-gradient(-45deg,#23231f 0,#23231f 11px,#2c2b27 11px,#2c2b27 12px);
  border-color:#2c2b27;
}
.ph--sand{
  background-color:#d9cdba;
  background-image:repeating-linear-gradient(-45deg,#d9cdba 0,#d9cdba 11px,#cdbfa8 11px,#cdbfa8 12px);
  border-color:#cdbfa8;
}
.ph__tag{
  font-family:var(--mono); font-size:11px; letter-spacing:.02em;
  color:var(--ink-42); padding:14px 16px;
  display:flex; align-items:center; gap:.6em;
}
.ph--char .ph__tag{ color:var(--on-dark-55); }
.ph__tag .sq{ width:7px; height:7px; border:1px solid currentColor; opacity:.7; }
.ph__foot{
  font-family:var(--mono); font-size:10.5px; letter-spacing:.04em;
  color:var(--ink-28); padding:14px 16px; text-transform:uppercase;
}
.ph--char .ph__foot{ color:var(--on-dark-35); }
.ph__center{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-28);
}

/* ===================================================================
   MECHANISM — charcoal reverse section (the heart)
   =================================================================== */
.mech{
  background:var(--charcoal);
  color:var(--on-dark);
  padding:clamp(110px,17vw,240px) var(--gutter);
  text-align:center;
  position:relative;
}
.mech .eyebrow{ color:var(--on-dark-35); }
.mech-statement{
  font-family:var(--display); font-weight:700;
  text-transform:lowercase; letter-spacing:-.03em; line-height:1;
  font-size:clamp(40px,7vw,104px);
  margin:clamp(22px,2.6vw,34px) 0 0;
}
.mech-line{
  margin-top:clamp(26px,3.2vw,46px);
  font-family:var(--display); font-weight:300;
  font-size:clamp(26px,4.4vw,62px);
  letter-spacing:-.02em; line-height:1.1;
  color:var(--on-dark-55);
  text-align:center;
}
.mech-line .fixed{ color:var(--on-dark-55); white-space:nowrap; }
.mech-cycle{
  position:relative; display:inline-block;
  color:var(--bone); min-width:1ch;
  transition:opacity .55s ease, transform .55s cubic-bezier(.2,.7,.2,1);
}
.mech-cycle.swap{ opacity:0; transform:translateY(.22em); }
.mech-foot{
  margin-top:clamp(48px,6vw,90px);
  font-family:var(--text); font-weight:300;
  font-size:clamp(13px,1.1vw,15px); letter-spacing:.02em;
  color:var(--on-dark-35); max-width:30ch; margin-left:auto; margin-right:auto;
  line-height:1.7;
}

/* ===================================================================
   CHAPTER 01 — products
   =================================================================== */
.chapter{ padding:var(--section-y) var(--gutter); }
.sec-head{
  display:grid; grid-template-columns:1fr; gap:18px;
  margin-bottom:clamp(48px,6vw,86px);
}
.sec-head__top{
  display:flex; justify-content:space-between; align-items:baseline;
  gap:24px; flex-wrap:wrap;
}
.sec-title{
  font-family:var(--display); font-weight:700;
  letter-spacing:-.03em; line-height:.98;
  font-size:clamp(34px,5.4vw,76px); text-transform:uppercase;
  margin:0;
}
.sec-intro{ max-width:40ch; }

.products{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:clamp(20px,2.4vw,40px);
}
/* WooCommerce loop outputs a <ul> — override */
ul.products{ list-style:none; padding:0; margin:0; }
.product{ display:flex; flex-direction:column; }
.product__media{
  position:relative; aspect-ratio:4/5; margin-bottom:22px; overflow:hidden;
}
.product__media img{ width:100%; height:100%; object-fit:cover; }
.product__media .ph{ transition:transform 1.2s cubic-bezier(.2,.7,.2,1); }
.product:hover .product__media .ph{ transform:scale(1.025); }
.product:hover .product__media img{ transform:scale(1.025); transition:transform 1.2s cubic-bezier(.2,.7,.2,1); }

/* subtle sleeve-secret reveal on the card */
.secret{
  position:absolute; left:16px; bottom:16px; z-index:3;
  font-family:var(--display); font-weight:300; letter-spacing:-.01em;
  font-size:clamp(15px,1.5vw,20px);
  color:var(--bone);
  opacity:0; transform:translateY(6px);
  transition:opacity .6s ease, transform .6s cubic-bezier(.2,.7,.2,1);
  text-shadow:0 1px 18px rgba(0,0,0,.35);
  pointer-events:none;
}
.product:hover .secret{ opacity:.96; transform:translateY(0); }
.product__media::after{
  content:""; position:absolute; inset:0; z-index:2;
  background:linear-gradient(to top, rgba(0,0,0,.28), transparent 46%);
  opacity:0; transition:opacity .6s ease; pointer-events:none;
}
.product:hover .product__media::after{ opacity:1; }

.product__row{
  display:flex; justify-content:space-between; align-items:baseline; gap:14px;
}
.product__name{
  font-family:var(--display); font-weight:600; letter-spacing:-.01em;
  font-size:clamp(18px,1.5vw,21px); text-transform:uppercase; margin:0;
}
.product__name a{ color:inherit; }
.product__price{
  font-family:var(--text); font-weight:400; font-size:15px; color:var(--ink-60);
  white-space:nowrap;
}
.product__spec{
  font-family:var(--mono); font-size:11px; letter-spacing:.03em;
  color:var(--ink-42); margin-top:9px; text-transform:uppercase;
}
.product__foot{
  display:flex; align-items:center; justify-content:space-between;
  margin-top:16px; padding-top:15px; border-top:1px solid var(--bone-line);
}
.swatches{ display:flex; gap:7px; }
.sw{ width:13px; height:13px; border-radius:50%; border:1px solid rgba(0,0,0,.14); }
.sw--bone{ background:var(--bone); } .sw--char{ background:var(--charcoal); }
.sw--sage{ background:var(--sage); } .sw--sand{ background:var(--sand); }
.product__cta{
  font-size:12.5px; letter-spacing:.05em; text-transform:uppercase;
  color:var(--ink-60); display:inline-flex; gap:.5em; align-items:center;
  transition:color .25s, gap .25s;
}
.product:hover .product__cta{ color:var(--ink); gap:.8em; }

/* ===================================================================
   CRAFT / SLEEVE SECRET system
   =================================================================== */
.craft{ padding:var(--section-y) var(--gutter); background:var(--bone-soft); }
.craft-grid{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:clamp(20px,3vw,56px); margin-top:clamp(40px,5vw,68px);
}
.detail__media{ position:relative; aspect-ratio:1/1; margin-bottom:22px; cursor:default; }
.detail__no{
  font-family:var(--mono); font-size:11px; letter-spacing:.18em;
  color:var(--ink-42); margin-bottom:12px;
}
.detail h3{
  font-family:var(--display); font-weight:600; letter-spacing:-.01em;
  font-size:clamp(19px,1.7vw,24px); margin:0 0 10px; text-transform:uppercase;
}
.detail p{ margin:0; max-width:34ch; }
.detail__tech{
  font-family:var(--mono); font-size:11px; letter-spacing:.02em;
  color:var(--ink-42); margin-top:14px; text-transform:uppercase;
}
.reveal-overlay{
  position:absolute; inset:0; z-index:3;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--display); font-weight:300;
  font-size:clamp(18px,2vw,26px); letter-spacing:-.01em;
  color:var(--bone);
  opacity:0; transition:opacity .7s ease;
  pointer-events:none; text-shadow:0 2px 22px rgba(0,0,0,.4);
}
.detail__media::after{
  content:""; position:absolute; inset:0; z-index:2;
  background:rgba(0,0,0,.30); opacity:0; transition:opacity .7s ease; pointer-events:none;
}
.detail__media:hover .reveal-overlay,
.detail__media.lit .reveal-overlay{ opacity:.97; }
.detail__media:hover::after,
.detail__media.lit::after{ opacity:1; }
.detail__hint{
  font-family:var(--mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink-28); margin-top:14px; display:flex; align-items:center; gap:.6em;
}

.spec-strip{
  display:flex; flex-wrap:wrap; align-items:center; gap:clamp(16px,3vw,44px);
  margin-top:clamp(56px,7vw,96px); padding-top:clamp(28px,3vw,40px);
  border-top:1px solid var(--bone-line);
}
.spec-strip .item{
  font-family:var(--display); font-weight:600; letter-spacing:-.01em;
  font-size:clamp(18px,2vw,26px); text-transform:uppercase;
}
.spec-strip .item small{
  display:block; font-family:var(--mono); font-weight:400;
  font-size:11px; letter-spacing:.04em; color:var(--ink-42);
  text-transform:uppercase; margin-top:6px;
}
.spec-strip .label-note{
  margin-left:auto; font-family:var(--text); font-weight:300; font-style:italic;
  color:var(--ink-60); font-size:clamp(14px,1.3vw,18px); max-width:26ch;
}

/* ===================================================================
   MANIFESTO
   =================================================================== */
.manifesto{ padding:var(--section-y) var(--gutter); }
.manifesto-inner{ max-width:min(92vw, 940px); margin:0 auto; }
.manifesto p{
  font-family:var(--display); font-weight:300;
  font-size:clamp(25px,3.5vw,46px); line-height:1.24;
  letter-spacing:-.02em; text-wrap:balance; margin:0;
}
.manifesto p .em{ color:var(--ink); }
.manifesto p .mut{ color:var(--ink-28); }
.manifesto-sign{
  margin-top:clamp(44px,5vw,72px); text-align:center;
}

/* ===================================================================
   EMAIL TEASER
   =================================================================== */
.teaser{
  padding:clamp(96px,13vw,200px) var(--gutter);
  background:var(--charcoal); color:var(--on-dark); text-align:center;
}
.teaser .eyebrow{ color:var(--on-dark-35); }
.teaser h2{
  font-family:var(--display); font-weight:700; letter-spacing:-.03em;
  font-size:clamp(34px,6vw,82px); margin:clamp(20px,2.4vw,30px) 0 0;
  text-transform:uppercase; line-height:.96;
}
.teaser p{ color:var(--on-dark-55); margin:22px auto 0; max-width:34ch; font-weight:300; }
.email-form{
  display:flex; gap:0; max-width:480px; margin:clamp(38px,4.5vw,60px) auto 0;
  border-bottom:1px solid var(--on-dark-35);
}
.email-form input{
  flex:1; background:none; border:none; outline:none;
  color:var(--on-dark); font-family:var(--text); font-size:16px;
  padding:14px 2px; letter-spacing:.01em;
}
.email-form input::placeholder{ color:var(--on-dark-35); }
.email-form button{
  background:none; border:none; color:var(--bone);
  font-size:13px; letter-spacing:.08em; text-transform:uppercase;
  padding:0 4px 0 18px; display:inline-flex; align-items:center; gap:.6em;
  transition:gap .25s;
}
.email-form button:hover{ gap:.95em; }
.email-note{
  font-family:var(--mono); font-size:10.5px; letter-spacing:.06em;
  color:var(--on-dark-35); text-transform:uppercase; margin-top:18px;
}
.email-ok{ color:var(--sage); font-weight:400; }

/* ===================================================================
   FOOTER
   =================================================================== */
.footer{ padding:clamp(64px,8vw,110px) var(--gutter) clamp(40px,4vw,60px); }
.footer-top{
  display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px;
  padding-bottom:clamp(48px,6vw,80px); border-bottom:1px solid var(--bone-line);
}
.footer-brand .mark{
  font-family:var(--display); font-weight:700; letter-spacing:-.025em;
  font-size:clamp(28px,3.4vw,46px); text-transform:uppercase; line-height:1;
}
.footer-brand .tag{
  font-family:var(--text); font-weight:500; font-size:11px;
  letter-spacing:.42em; text-transform:uppercase; color:var(--ink-42); margin-top:14px;
}
.footer-col h4{
  font-family:var(--text); font-weight:500; font-size:11px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--ink-42); margin:0 0 18px;
}
.footer-col ul{ list-style:none; margin:0; padding:0; display:grid; gap:11px; }
.footer-col a{ color:var(--ink-60); font-size:14px; transition:color .25s; }
.footer-col a:hover{ color:var(--ink); }
.footer-bottom{
  display:flex; justify-content:space-between; align-items:center;
  gap:24px; flex-wrap:wrap; padding-top:28px;
}
.footer-bottom .legal{
  font-family:var(--mono); font-size:11px; letter-spacing:.03em; color:var(--ink-28);
  text-transform:uppercase;
}
.footer-bottom .closing{
  font-family:var(--display); font-weight:400; font-size:clamp(15px,1.4vw,19px);
  letter-spacing:-.01em;
}
.hashtags{
  font-family:var(--mono); font-size:11px; letter-spacing:.02em; color:var(--ink-42);
  margin-top:14px; text-transform:lowercase;
}

/* ===================================================================
   Reveal on scroll
   =================================================================== */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity 1s ease, transform 1s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; }
.reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; }

@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto; }
  .reveal{ opacity:1; transform:none; }
  .rule{ transform:scaleX(1); }
}

/* ===================================================================
   SHOP PAGE (WooCommerce archive)
   =================================================================== */
.shop-page .chapter{ padding-top:calc(var(--gutter) + 78px); }

/* ===================================================================
   SINGLE PRODUCT PAGE
   =================================================================== */
.product-breadcrumb{
  padding:clamp(96px,12vw,160px) var(--gutter) 0;
}
.product-detail{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);
  gap:clamp(32px,5vw,80px);
  padding:clamp(28px,4vw,56px) var(--gutter) var(--section-y);
  align-items:start;
}
.product-detail__gallery{}
.product-gallery{ position:relative; aspect-ratio:4/5; overflow:hidden; }
.product-gallery__slide{ display:none; width:100%; height:100%; }
.product-gallery__slide.active{ display:block; }
.product-gallery__slide img{ width:100%; height:100%; object-fit:cover; }
.product-gallery__thumbs{
  display:flex; gap:8px; margin-top:10px; flex-wrap:wrap;
}
.gallery-thumb{
  width:64px; height:64px; padding:0; border:1px solid transparent; overflow:hidden;
  background:none; transition:border-color .2s;
}
.gallery-thumb.active{ border-color:var(--ink); }
.gallery-thumb img{ width:100%; height:100%; object-fit:cover; }
.product-detail__placeholder{ aspect-ratio:4/5; }

.product-detail__info{ position:sticky; top:calc(var(--gutter) + 78px); }
.product-detail__title{
  font-family:var(--display); font-weight:700; letter-spacing:-.03em;
  font-size:clamp(28px,3.5vw,46px); text-transform:uppercase;
  margin:10px 0 0; line-height:.98;
}
.product-detail__price{
  font-family:var(--text); font-size:clamp(18px,1.8vw,22px);
  color:var(--ink-60); margin:16px 0 0;
}
.product-detail__price .woocommerce-Price-amount{ color:var(--ink); }
.product-detail__desc{
  margin-top:clamp(20px,2.5vw,32px);
  font-size:clamp(14px,1.2vw,16px);
}
.product-detail__secret{
  margin-top:clamp(24px,3vw,40px);
  padding-top:clamp(20px,2.5vw,30px);
  border-top:1px solid var(--bone-line);
}
.product-detail__secret-text{
  font-family:var(--display); font-weight:300; letter-spacing:-.01em;
  font-size:clamp(20px,2.2vw,28px); margin:10px 0 0; color:var(--ink-60);
}

/* ===================================================================
   DNEVNIK (blog archive)
   =================================================================== */
.dnevnik-archive{ padding-bottom:var(--section-y); }
.dnevnik-head{ padding:calc(var(--gutter) + 78px) var(--gutter) 0; }
.dnevnik-grid{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:clamp(28px,3vw,56px);
  padding:clamp(48px,6vw,80px) var(--gutter) 0;
}
.dnevnik-card{}
.dnevnik-card__thumb{ display:block; aspect-ratio:3/2; overflow:hidden; margin-bottom:20px; }
.dnevnik-card__thumb img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s cubic-bezier(.2,.7,.2,1); }
.dnevnik-card:hover .dnevnik-card__thumb img{ transform:scale(1.025); }
.dnevnik-card__thumb--empty .ph{ height:100%; }
.dnevnik-card__title{
  font-family:var(--display); font-weight:600; letter-spacing:-.02em;
  font-size:clamp(20px,2vw,26px); margin:8px 0; text-transform:uppercase;
}
.dnevnik-card__title a{ color:inherit; }
.dnevnik-card__excerpt{ color:var(--ink-60); font-size:14px; margin:0 0 14px; }
.dnevnik-pagination{
  padding:clamp(40px,5vw,64px) var(--gutter) 0;
  display:flex; justify-content:center;
}
.dnevnik-pagination .page-numbers{
  font-family:var(--mono); font-size:13px; letter-spacing:.08em;
  color:var(--ink-42); padding:8px 12px; border:1px solid transparent;
  transition:border-color .2s, color .2s;
}
.dnevnik-pagination .current{ color:var(--ink); border-color:var(--ink); }

/* ===================================================================
   PAGE templates (generic, o-nas)
   =================================================================== */
.site-page .page-wrap, .single-wrap{
  padding:calc(var(--gutter) + 78px) var(--gutter) var(--section-y);
  max-width:860px;
}
.page-article__header{ margin-bottom:clamp(32px,4vw,56px); }
.page-article__body{ font-size:clamp(15px,1.3vw,17px); line-height:1.7; color:var(--ink-60); }
.page-article__body h2, .page-article__body h3{ font-family:var(--display); color:var(--ink); }
.page-intro{
  padding:calc(var(--gutter) + 78px) var(--gutter) clamp(40px,5vw,64px);
  border-bottom:1px solid var(--bone-line);
}

/* ===================================================================
   SINGLE POST
   =================================================================== */
.single-article__header{ margin-bottom:clamp(32px,4vw,56px); }
.single-article__featured{ margin-bottom:clamp(32px,4vw,56px); }
.single-hero-img{ width:100%; max-height:60vh; object-fit:cover; }
.single-article__body{ font-size:clamp(15px,1.3vw,18px); line-height:1.75; color:var(--ink-60); }
.single-article__body h2{ font-family:var(--display); font-weight:600; color:var(--ink); text-transform:uppercase; }
.single-article__body blockquote{
  border-left:2px solid var(--ink-28); margin:clamp(28px,3vw,40px) 0;
  padding-left:clamp(18px,2.4vw,32px); font-style:italic;
  font-family:var(--display); font-size:clamp(18px,1.8vw,24px);
  color:var(--ink-42); letter-spacing:-.01em;
}
.post-nav{
  display:flex; justify-content:space-between; gap:24px; flex-wrap:wrap;
  padding-top:clamp(32px,4vw,56px); margin-top:clamp(32px,4vw,56px);
  border-top:1px solid var(--bone-line);
}
.post-nav__prev, .post-nav__next{
  display:flex; flex-direction:column; gap:6px; max-width:40%;
  font-family:var(--display); font-weight:600; font-size:clamp(15px,1.4vw,18px);
  text-transform:uppercase; letter-spacing:-.01em; color:var(--ink-60);
  transition:color .25s;
}
.post-nav__prev:hover, .post-nav__next:hover{ color:var(--ink); }
.post-nav__next{ align-items:flex-end; text-align:right; }

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media (max-width: 1020px){
  .footer-top{ grid-template-columns:1fr 1fr; }
  .footer-brand{ grid-column:1 / -1; margin-bottom:14px; }
  .product-detail{ grid-template-columns:1fr; }
  .product-detail__info{ position:static; }
}
@media (max-width: 880px){
  .nav-links{ display:none; }
  .nav-menu-btn{ display:block; }
  .hero{
    grid-template-columns:1fr; align-items:start; gap:36px;
    min-height:auto; padding-top:calc(var(--gutter) + 92px);
  }
  .hero-figure{ order:2; min-height:78vh; }
  .hero-copy{ order:1; }
  .products{ grid-template-columns:1fr; gap:48px; }
  .product__media{ aspect-ratio:4/5; }
  .craft-grid{ grid-template-columns:1fr; gap:48px; }
  .spec-strip{ flex-direction:column; align-items:flex-start; gap:24px; }
  .spec-strip .label-note{ margin-left:0; }
  .secret{ opacity:.6; transform:none; }
  .dnevnik-grid{ grid-template-columns:1fr; }
}
@media (max-width: 560px){
  .nav-cart .word{ display:none; }
  .hero-actions{ gap:18px; }
  .btn{ width:100%; justify-content:center; }
  .btn--ghost{ width:auto; }
  .footer-top{ grid-template-columns:1fr; }
  .footer-bottom{ flex-direction:column; align-items:flex-start; gap:16px; }
}

/* Mobile slide-out menu */
.mobile-menu{
  position:fixed; inset:0; z-index:95; background:var(--bone);
  display:flex; flex-direction:column; padding:var(--gutter);
  transform:translateY(-100%); transition:transform .5s cubic-bezier(.2,.7,.2,1);
}
.mobile-menu.open{ transform:translateY(0); }
.mobile-menu .mm-head{ display:flex; justify-content:space-between; align-items:center; }
.mobile-menu .mm-close{ background:none; border:none; font-size:28px; line-height:1; }
.mobile-menu nav{ margin-top:auto; margin-bottom:auto; display:grid; gap:8px; }
.mobile-menu nav a, .mobile-menu nav li a{
  font-family:var(--display); font-weight:700; text-transform:uppercase;
  font-size:clamp(34px,11vw,58px); letter-spacing:-.03em; line-height:1.04;
  display:block;
}
/* WP menu list in mobile nav */
.mobile-menu nav ul{ list-style:none; padding:0; margin:0; display:grid; gap:8px; }
.mobile-menu nav li{ margin:0; }
.mobile-menu .mm-foot{ font-family:var(--mono); font-size:11px; letter-spacing:.04em; color:var(--ink-42); }
