/* Tvoros Pamatai — design system */
:root{
  --paper:#f2efe9;
  --paper-2:#ebe7df;
  --ink:#141414;
  --ink-soft:#2b2a27;
  --anthracite:#2b2f32;
  --clay:#8b6a4e;
  --rule:rgba(20,20,20,.14);
  --muted:rgba(20,20,20,.58);
  --serif:"Instrument Serif", ui-serif, Georgia, serif;
  --sans:"Switzer", ui-sans-serif, system-ui;
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);color:var(--ink);
  font-family:var(--sans);font-weight:400;font-size:16px;line-height:1.55;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;
  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'/><feColorMatrix values='0 0 0 0 0.08  0 0 0 0 0.08  0 0 0 0 0.08  0 0 0 0.06 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode:multiply;opacity:.55;
}
.wrap{max-width:1360px;margin:0 auto;padding:0 clamp(20px,4vw,56px)}

/* NAV */
nav.top{position:fixed;top:0;left:0;right:0;z-index:50;backdrop-filter:saturate(1.2) blur(14px);-webkit-backdrop-filter:saturate(1.2) blur(14px);background:rgba(242,239,233,.72);border-bottom:1px solid var(--rule)}
nav.top .inner{display:flex;align-items:center;justify-content:space-between;height:68px}
.mark{font-family:var(--serif);font-size:22px;letter-spacing:-.01em;line-height:1;display:flex;align-items:center;gap:10px}
.mark .dot{width:8px;height:8px;background:var(--anthracite);border-radius:50%;display:inline-block;transform:translateY(-1px)}
.mark em{font-style:italic;font-weight:400}
.navlinks{display:flex;gap:36px;font-size:13px;letter-spacing:.02em;text-transform:uppercase;font-weight:500}
.navlinks a{position:relative;padding:6px 0;color:var(--ink-soft)}
.navlinks a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:var(--ink);transition:right .4s cubic-bezier(.2,.7,.2,1)}
.navlinks a:hover,.navlinks a.active{color:var(--ink)}
.navlinks a:hover::after,.navlinks a.active::after{right:0}
.cartbtn{font-size:13px;font-weight:500;letter-spacing:.02em;border:1px solid var(--ink);border-radius:999px;padding:9px 18px;background:transparent;color:var(--ink);transition:background .25s,color .25s;display:inline-block}
.cartbtn:hover{background:var(--ink);color:var(--paper)}

/* Hero */
.hero{position:relative;padding:140px 0 40px;overflow:hidden}
.hero .eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:500}
.hero .eyebrow::before{content:"";width:28px;height:1px;background:var(--ink)}
.hero h1{font-family:var(--serif);font-weight:400;font-size:clamp(56px,9.2vw,148px);line-height:.96;letter-spacing:-.025em;margin:28px 0 28px;max-width:12ch}
.hero h1 em{font-style:italic;color:var(--anthracite)}
.hero .lede{max-width:48ch;font-size:clamp(16px,1.2vw,19px);color:var(--ink-soft);line-height:1.55}
.hero-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(32px,5vw,72px);align-items:end;margin-top:60px}
.hero-photo{position:relative;aspect-ratio:4/5;border-radius:2px;overflow:hidden;box-shadow:0 40px 80px -40px rgba(20,20,20,.35)}
.hero-photo img{width:100%;height:100%;object-fit:cover;transform:scale(1.02);transition:transform 1.2s ease}
.hero-photo:hover img{transform:scale(1.06)}
.hero-photo .tag{position:absolute;left:20px;bottom:20px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;background:rgba(242,239,233,.92);padding:8px 12px;border-radius:2px}
.hero-meta{display:flex;flex-direction:column;gap:36px;padding-bottom:12px}
.hero-meta .row{display:flex;justify-content:space-between;align-items:baseline;gap:24px;padding:18px 0;border-top:1px solid var(--rule)}
.hero-meta .row:last-child{border-bottom:1px solid var(--rule)}
.hero-meta .k{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.hero-meta .v{font-family:var(--serif);font-size:24px;letter-spacing:-.01em}

.btn{display:inline-flex;align-items:center;gap:10px;font-size:14px;font-weight:500;letter-spacing:.01em;padding:14px 22px;border-radius:999px;border:1px solid transparent;transition:transform .25s,background .25s,color .25s,border-color .25s;background:transparent;color:inherit;cursor:pointer}
.btn .arr{display:inline-block;transition:transform .3s cubic-bezier(.2,.7,.2,1)}
.btn:hover .arr{transform:translateX(4px)}
.btn-dark{background:var(--ink);color:var(--paper)}
.btn-dark:hover{background:var(--anthracite)}
.btn-ghost{border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn-paper{border:1px solid var(--paper);color:var(--paper)}
.btn-paper:hover{background:var(--paper);color:var(--ink)}
.btn:disabled{opacity:.4;cursor:not-allowed}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}

.strip{margin-top:80px;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);overflow:hidden}
.strip-inner{display:flex;gap:64px;padding:22px 0;font-family:var(--serif);font-size:22px;letter-spacing:-.01em;white-space:nowrap;animation:slide 42s linear infinite}
.strip-inner span{display:inline-flex;align-items:center;gap:64px;color:var(--ink-soft)}
.strip-inner em{font-style:italic;color:var(--clay)}
.strip-inner .sep{width:6px;height:6px;background:var(--ink);border-radius:50%}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

.sect{padding:clamp(80px,10vw,160px) 0;position:relative}
.sect-label{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:12px;font-weight:500}
.sect-label::before{content:"";width:28px;height:1px;background:var(--ink)}
.sect h2,.page h2,.page h1.sect-h{font-family:var(--serif);font-weight:400;font-size:clamp(40px,5.6vw,80px);line-height:1;letter-spacing:-.02em;margin:22px 0 0;max-width:18ch}
.sect h2 em,.page h2 em,.page h1.sect-h em{font-style:italic;color:var(--anthracite)}

.apie{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(40px,7vw,110px);align-items:center}
.apie-photo{aspect-ratio:1/1;overflow:hidden;border-radius:2px}
.apie-photo img{width:100%;height:100%;object-fit:cover}
.apie-text p{font-size:18px;color:var(--ink-soft);max-width:50ch;margin:28px 0}
.apie-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px;border-top:1px solid var(--rule);padding-top:28px}
.apie-stats .s .n{font-family:var(--serif);font-size:44px;line-height:1;letter-spacing:-.02em}
.apie-stats .s .l{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:8px}

.prod-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px;margin-bottom:56px}
.prod-head .right{display:flex;gap:8px}
.chip{font-size:12px;letter-spacing:.08em;text-transform:uppercase;font-weight:500;padding:9px 16px;border:1px solid var(--rule);border-radius:999px;cursor:pointer;transition:all .2s;background:transparent;color:var(--ink)}
.chip.on,.chip:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.card{position:relative;display:flex;flex-direction:column;background:var(--paper-2);border-radius:2px;overflow:hidden;transition:transform .5s cubic-bezier(.2,.7,.2,1),box-shadow .5s}
.card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -40px rgba(20,20,20,.4)}
.card .photo{aspect-ratio:4/5;overflow:hidden;background:#ddd}
.card .photo img{width:100%;height:100%;object-fit:cover;transition:transform 1s}
.card:hover .photo img{transform:scale(1.05)}
.card .body{padding:22px 22px 24px;display:flex;flex-direction:column;gap:6px}
.card .meta{display:flex;justify-content:space-between;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.card .name{font-family:var(--serif);font-size:26px;letter-spacing:-.01em;line-height:1.1;margin:8px 0 2px}
.card .dim{font-size:13px;color:var(--muted);letter-spacing:.04em}
.card .foot{display:flex;justify-content:space-between;align-items:baseline;margin-top:18px;padding-top:16px;border-top:1px solid var(--rule)}
.card .price{font-family:var(--serif);font-size:28px;letter-spacing:-.01em}
.card .price sup{font-size:14px;color:var(--muted);font-style:italic}
.card .add{font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;background:transparent;border:none;padding:0;color:var(--ink)}
.card .add span{border-bottom:1px solid var(--ink);padding-bottom:3px;transition:opacity .2s}
.card .add:hover span{opacity:.5}

/* Configurator (dark block) */
.cfg{background:var(--ink);color:var(--paper);border-radius:2px;padding:clamp(40px,6vw,80px);position:relative;overflow:hidden}
.cfg::before{content:"";position:absolute;inset:-40%;background:radial-gradient(ellipse at 20% 20%, rgba(139,106,78,.25), transparent 50%),radial-gradient(ellipse at 80% 80%, rgba(43,47,50,.9), transparent 55%);pointer-events:none}
.cfg > *{position:relative}
.cfg .sect-label{color:rgba(242,239,233,.65)}
.cfg .sect-label::before{background:var(--paper)}
.cfg h2{color:var(--paper)}
.cfg h2 em{color:var(--clay)}

/* Gallery */
.gal{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;margin-top:56px}
.gal .g{overflow:hidden;border-radius:2px;cursor:pointer}
.gal .g img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s}
.gal .g:hover img{transform:scale(1.08)}
.gal .g.big{grid-column:span 2;grid-row:span 2;aspect-ratio:1/1}
.gal .g.wide{grid-column:span 3;aspect-ratio:16/9}
.gal .g.std{grid-column:span 2;aspect-ratio:4/3}

/* Contact */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:28px}
.ci-row{display:flex;flex-direction:column;gap:6px;border-top:1px solid var(--rule);padding-top:22px}
.ci-row .k{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.ci-row .v{font-family:var(--serif);font-size:32px;letter-spacing:-.01em}
.ci-row .v a:hover{color:var(--anthracite)}
.form{display:flex;flex-direction:column;gap:14px}
.form label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:10px}
.form input,.form textarea,.form select{background:transparent;border:none;border-bottom:1px solid var(--rule);padding:14px 2px;font-family:var(--sans);font-size:15px;color:var(--ink);transition:border-color .25s;border-radius:0}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-bottom-color:var(--ink)}
.form textarea{min-height:100px;resize:vertical}
.form .btn{align-self:flex-start;margin-top:16px}

footer{border-top:1px solid var(--rule);padding:50px 0 40px;margin-top:60px;position:relative;z-index:2}
.foot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:24px;font-size:13px;color:var(--muted)}
.foot .mark{color:var(--ink)}

/* Page load stagger */
.rise{opacity:0;transform:translateY(22px);animation:rise .9s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes rise{to{opacity:1;transform:none}}
.d1{animation-delay:.05s}.d2{animation-delay:.15s}.d3{animation-delay:.28s}
.d4{animation-delay:.42s}.d5{animation-delay:.56s}.d6{animation-delay:.7s}

/* Page top padding (for fixed nav) */
.page{padding-top:120px}
.page-header{margin-bottom:60px}

/* Shop page: product config panel */
.shop{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(32px,5vw,80px);margin-top:60px;align-items:start}
.shop-left{display:flex;flex-direction:column;gap:48px}
.panel{background:var(--paper-2);border-radius:2px;padding:clamp(24px,3vw,40px)}
.panel h3{font-family:var(--serif);font-size:28px;margin:0 0 20px;font-weight:400;letter-spacing:-.01em}
.opts{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.opt{border:1px solid var(--rule);border-radius:2px;padding:16px;cursor:pointer;background:transparent;text-align:left;transition:all .2s;color:var(--ink);font-family:inherit}
.opt:hover{border-color:var(--ink)}
.opt.on{border-color:var(--ink);background:var(--ink);color:var(--paper)}
.opt .t{font-family:var(--serif);font-size:20px;letter-spacing:-.01em;display:block}
.opt .s{font-size:12px;letter-spacing:.04em;color:var(--muted);margin-top:4px;display:block}
.opt.on .s{color:rgba(242,239,233,.65)}
.swatches{display:flex;gap:10px;flex-wrap:wrap}
.sw{width:44px;height:44px;border-radius:50%;border:2px solid transparent;cursor:pointer;position:relative;transition:transform .2s}
.sw:hover{transform:scale(1.05)}
.sw.on{border-color:var(--ink);box-shadow:0 0 0 2px var(--paper) inset}
.sw-lbl{font-size:11px;color:var(--muted);margin-top:10px;letter-spacing:.08em}
.qty{display:flex;align-items:center;gap:0;border:1px solid var(--rule);border-radius:999px;width:fit-content}
.qty button{width:40px;height:40px;background:transparent;border:none;font-size:18px;color:var(--ink)}
.qty button:hover{background:var(--ink);color:var(--paper);border-radius:999px}
.qty input{width:60px;border:none;background:transparent;text-align:center;font-family:var(--serif);font-size:22px;color:var(--ink)}
.qty input:focus{outline:none}

/* Cart (dark panel) */
.cart{position:sticky;top:100px;background:var(--ink);color:var(--paper);border-radius:2px;padding:clamp(24px,3vw,40px);display:flex;flex-direction:column;gap:22px}
.cart h3{font-family:var(--serif);font-size:30px;margin:0;font-weight:400;letter-spacing:-.01em;color:var(--paper)}
.cart-empty{color:rgba(242,239,233,.55);font-size:14px}
.cart-items{display:flex;flex-direction:column;gap:14px}
.ci{display:flex;justify-content:space-between;gap:12px;padding-bottom:14px;border-bottom:1px solid rgba(242,239,233,.12);align-items:flex-start}
.ci .t{font-family:var(--serif);font-size:18px;letter-spacing:-.01em}
.ci .d{font-size:12px;color:rgba(242,239,233,.6);margin-top:4px}
.ci .p{font-family:var(--serif);font-size:20px;white-space:nowrap}
.ci .rm{background:transparent;border:none;color:rgba(242,239,233,.55);font-size:11px;letter-spacing:.12em;text-transform:uppercase;padding:0;margin-top:6px}
.ci .rm:hover{color:var(--clay)}
.cart-sum{display:flex;flex-direction:column;gap:10px;padding-top:10px}
.cart-sum .row{display:flex;justify-content:space-between;font-size:14px;color:rgba(242,239,233,.72)}
.cart-sum .row.total{padding-top:14px;border-top:1px solid rgba(242,239,233,.2);margin-top:10px;color:var(--paper);align-items:baseline}
.cart-sum .row.total .k{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:rgba(242,239,233,.6)}
.cart-sum .row.total .v{font-family:var(--serif);font-size:44px;line-height:1}
.cart-sum .row.total .v em{color:var(--clay);font-style:italic}

/* Checkout */
.checkout{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;margin-top:60px}
.checkout .form{gap:18px}
.checkout-summary{background:var(--paper-2);border-radius:2px;padding:32px;position:sticky;top:100px;height:fit-content}
.checkout-summary h3{font-family:var(--serif);font-size:26px;margin:0 0 18px;font-weight:400}
.checkout-summary .row{display:flex;justify-content:space-between;padding:10px 0;font-size:14px;color:var(--ink-soft);border-bottom:1px solid var(--rule)}
.checkout-summary .row.total{padding-top:18px;border-bottom:none;margin-top:8px;align-items:baseline}
.checkout-summary .row.total .k{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.checkout-summary .row.total .v{font-family:var(--serif);font-size:40px;letter-spacing:-.02em}

.hint{font-size:12px;color:var(--muted);margin-top:-6px}
.hint a{border-bottom:1px solid var(--ink)}

.note{background:var(--paper-2);border-left:3px solid var(--clay);padding:16px 20px;font-size:14px;color:var(--ink-soft);margin:20px 0;border-radius:0 2px 2px 0}

.toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(40px);background:var(--ink);color:var(--paper);padding:14px 24px;border-radius:999px;font-size:14px;letter-spacing:.02em;z-index:100;opacity:0;transition:all .4s cubic-bezier(.2,.7,.2,1);pointer-events:none}
.toast.on{transform:translateX(-50%) translateY(0);opacity:1}

@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr}
  .apie{grid-template-columns:1fr}
  .prod-grid{grid-template-columns:repeat(2,1fr)}
  .gal{grid-template-columns:repeat(4,1fr)}
  .gal .g.wide{grid-column:span 4}
  .contact{grid-template-columns:1fr}
  .navlinks{display:none}
  .shop{grid-template-columns:1fr}
  .cart{position:static}
  .checkout{grid-template-columns:1fr}
  .checkout-summary{position:static}
}
@media (max-width:560px){
  .prod-grid{grid-template-columns:1fr}
  .gal{grid-template-columns:repeat(2,1fr)}
  .gal .g{grid-column:span 2!important;grid-row:span 1!important;aspect-ratio:4/3!important}
  .opts{grid-template-columns:1fr}
}
