/* ==========================================================================
   Privaed — homepage section styles (loaded only on the front page).
   Hero, intro/what-is, features + gallery, videos, configurator wrap,
   categories, plus the CSS-3D louvre motif + image placeholders.
   ========================================================================== */

/* ribi / louvre motif (pure CSS rectangles, slats injected by home.js) */
.louvre{position:relative;display:flex;align-items:stretch;perspective:560px}
.louvre .post{width:11px;border-radius:6px;background:linear-gradient(180deg,#c0925270,#8c653570)}
.louvre .slats{flex:1;display:flex;flex-direction:column;justify-content:center;gap:8px;padding:14px 8px;transform-style:preserve-3d}
.louvre .slat{height:14px;border-radius:7px;background:linear-gradient(180deg,#EBB867,#C68A38);box-shadow:0 1px 2px rgba(0,0,0,.18);transform-origin:center}

/* image placeholder (gallery/category fallback) */
.ph{position:relative;border-radius:var(--r-md);overflow:hidden;background:repeating-linear-gradient(135deg, #EBDDC4 0 11px, #E3D2B4 11px 22px);display:flex;align-items:flex-end;justify-content:flex-start}
.ph::before{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(255,255,255,.25),transparent 60%)}
.ph .tag{position:relative;margin:12px;font-family:ui-monospace,"SFMono-Regular",Menlo,monospace;font-size:10.5px;letter-spacing:.02em;color:#7a6c54;background:rgba(255,253,248,.86);padding:4px 9px;border-radius:8px}
.ph img{width:100%;height:100%;object-fit:cover}
.ph.dark{background:repeating-linear-gradient(135deg,#2a241b 0 11px,#241e16 11px 22px)}
.ph.dark .tag{color:#cdbfa3;background:rgba(20,15,9,.6)}

/* ===== HERO ===== */
.hero{padding:6px 0 4px}
.hero-card{position:relative;border-radius:var(--r-card);overflow:hidden;min-height:580px;display:flex;flex-direction:column;justify-content:flex-end;padding:48px;box-shadow:var(--shadow-lg);background:radial-gradient(130% 90% at 80% 12%, rgba(232,168,72,.40), transparent 52%),radial-gradient(80% 60% at 8% 100%, rgba(255,205,130,.14), transparent 60%),linear-gradient(140deg,#2B2117 0%, #1B150E 58%, #120D07 100%)}
.hero-photo{position:absolute;inset:0;z-index:0;width:100%;height:100%;object-fit:cover}
.hero-card::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(0deg, rgba(8,6,3,.78), rgba(8,6,3,.30) 55%, rgba(8,6,3,.30))}
.hero-tag{position:absolute;top:22px;left:22px;z-index:3;font-size:11.5px;letter-spacing:.04em;white-space:nowrap;color:rgba(255,236,205,.6);background:rgba(0,0,0,.32);padding:6px 13px;border-radius:var(--r-pill);backdrop-filter:blur(4px);font-weight:500}
.hero-content{position:relative;z-index:3;max-width:730px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:9px;color:#F2C988;font-weight:700;font-size:13px;letter-spacing:.13em;text-transform:uppercase;margin-bottom:20px}
.hero-eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--amber)}
.hero h1{color:#FBF4E6;font-size:clamp(40px,5vw,66px);font-weight:800;letter-spacing:-.03em}
.hero h1 .hl{color:#F2BC6A}
.hero p.sub{color:rgba(247,235,214,.86);font-size:19px;max-width:480px;margin-top:20px}
.hero-actions{display:flex;align-items:center;gap:16px;margin-top:32px;flex-wrap:wrap}
.hero-actions .btn-ghost{color:#FBF4E6;border-color:rgba(255,255,255,.32)}
.hero-actions .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.06)}
.partners{position:absolute;right:32px;bottom:34px;z-index:3;display:flex;align-items:center;gap:18px;background:rgba(20,15,9,.46);backdrop-filter:blur(8px);padding:14px 22px;border-radius:var(--r-pill)}
.partners .lbl{font-size:11px;color:rgba(255,236,205,.62);max-width:96px;line-height:1.3;font-weight:500}
.partners .logos{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.partners img{height:18px;width:auto;max-width:100%;opacity:.9}
.partners img.bauhof{height:15px}
@media(max-width:900px){.partners{position:static;margin-top:28px;flex-wrap:wrap;border-radius:var(--r-md)}}

/* ===== INTRO / WHAT IS ===== */
.intro-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:22px}
.contact-card{background:linear-gradient(165deg,#E3A23B,#C9842A);border-radius:var(--r-card);padding:36px;color:#2a1d05;position:relative;overflow:hidden;display:flex;flex-direction:column}
.contact-card::after{content:"";position:absolute;right:-40px;bottom:-40px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.22),transparent 70%)}
.contact-card h3{color:#2a1d05;font-size:27px;font-weight:800}
.contact-card .intro-lede{color:#3a2806;opacity:.85;margin-top:12px;font-size:15px;max-width:280px}
.contact-card .person{display:flex;align-items:center;gap:16px;margin-top:auto;padding-top:32px;position:relative;z-index:1}
.avatar{width:64px;height:64px;border-radius:50%;flex:none;background:linear-gradient(160deg,#caa05f,#9c7536);display:grid;place-items:center;color:#2a1d05;font-weight:700;font-family:"Epilogue",system-ui,sans-serif;font-size:20px;border:2px solid rgba(255,255,255,.4);overflow:hidden}
.avatar img{width:100%;height:100%;object-fit:cover}
.contact-card .nm{font-weight:700;font-size:17px}
.contact-card .role{font-size:13.5px;opacity:.75}
.contact-card .lines{margin-top:18px;font-size:14.5px;line-height:1.9;font-weight:500;position:relative;z-index:1}
.contact-card .lines a{border-bottom:1px solid rgba(42,29,5,.3)}
.what-card{background:var(--cream-2);border-radius:var(--r-card);padding:40px;display:flex;flex-direction:column;box-shadow:0 20px 50px -28px rgba(64,46,16,.22)}
.what-card h2{font-size:clamp(26px,2.6vw,34px);font-weight:800;margin-top:14px}
.what-card p{color:var(--body);font-size:17px;margin-top:16px;max-width:440px}
.states{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:auto;padding-top:34px;max-width:340px}
.state{text-align:center}
/* näidis photos are 1000×1500 (2:3) — show them in full, no crop. Identical
   aspect across all three keeps the row even. */
.state .frame{border-radius:var(--r-md);overflow:hidden}
.state .frame img{width:100%;height:auto;display:block}
.state .cap{font-size:12px;font-weight:600;color:var(--muted);margin-top:9px}

/* ===== HOW IT WORKS ===== */
.features{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:30px}
.feat-chip{display:flex;align-items:center;gap:11px;background:#fff;border-radius:var(--r-pill);padding:11px 20px 11px 13px;box-shadow:0 4px 16px -8px rgba(64,46,16,.20);transition:.18s}
.feat-chip:hover{transform:translateY(-2px);box-shadow:0 10px 24px -10px rgba(64,46,16,.26)}
.feat-chip .ic{width:38px;height:38px;border-radius:50%;background:var(--amber-soft);color:var(--amber-deep);display:grid;place-items:center;flex:none}
.feat-chip .ic svg{width:20px;height:20px}
.feat-chip span{font-weight:600;font-size:15px;color:var(--ink)}
.gallery{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;border-radius:var(--r-card);overflow:hidden}
.gallery .ph{aspect-ratio:3/4}
.gallery .ph:nth-child(1){aspect-ratio:auto}

/* ===== VIDEOS ===== */
.videos{background:var(--dark);border-radius:var(--r-card);padding:54px 48px;color:var(--cream);position:relative;overflow:hidden}
.videos .vhead{position:relative;display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:36px;flex-wrap:wrap}
.videos h2{color:var(--cream);font-size:clamp(28px,3.2vw,42px);font-weight:800;margin-top:14px}
.videos .vhead .eyebrow{color:#F2C988}
.videos .vhead p{color:rgba(247,235,214,.66);margin-top:14px;max-width:440px;font-size:16px}
.reels{position:relative;display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.reel{aspect-ratio:9/16;border-radius:var(--r-md);position:relative;overflow:hidden;background:linear-gradient(170deg,#3a3024,#211a12);cursor:pointer;transition:.2s}
.reel:hover{transform:translateY(-4px)}
.reel video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.reel .play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:52px;height:52px;border-radius:50%;background:rgba(255,253,248,.92);display:grid;place-items:center;box-shadow:0 8px 20px rgba(0,0,0,.35);transition:.2s;z-index:2}
.reel:hover .play{transform:translate(-50%,-50%) scale(1.08);background:#fff}
.reel.playing .play{opacity:0;pointer-events:none}
.reel .play svg{width:18px;height:18px;color:#211a12;margin-left:2px}
.reel .dur{position:absolute;bottom:12px;left:12px;z-index:2;font-size:11px;font-weight:600;background:rgba(0,0,0,.5);color:#fff;padding:3px 9px;border-radius:var(--r-pill);backdrop-filter:blur(3px)}
/* ===== CATEGORIES ===== */
.cats{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.cat{position:relative;border-radius:var(--r-card);overflow:hidden;min-height:280px;display:flex;flex-direction:column;justify-content:flex-end;padding:32px;color:#fff;transition:.22s;border:1px solid transparent}
.cat:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.cat.tall{min-height:340px}
.cat .bg{position:absolute;inset:0;z-index:0}
.cat .bg img{width:100%;height:100%;object-fit:cover}
.cat .ph{position:absolute;inset:0;border-radius:0}
.cat .ph .tag{margin:14px}
.cat .scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(0deg,rgba(15,11,6,.78) 8%,rgba(15,11,6,.15) 60%,transparent)}
.cat.amber{background:linear-gradient(155deg,#E3A23B,#C28323);color:#241902}
.cat.amber .scrim{display:none}
.cat.amber h3{color:#241902}
.cat.amber .price{background:rgba(255,255,255,.9)}
.cat .c{position:relative;z-index:2}
.cat h3{font-size:23px;font-weight:800;color:inherit}
.cat p{font-size:14.5px;margin-top:8px;opacity:.85;max-width:330px}
.cat .go{display:inline-flex;align-items:center;gap:8px;margin-top:16px;font-weight:700;font-size:14px}
.cat .go svg{width:16px;height:16px;transition:transform .2s}
.cat:hover .go svg{transform:translateX(4px)}
.cat .price{position:absolute;top:24px;right:24px;z-index:2;background:rgba(255,253,248,.92);color:var(--ink);font-weight:700;font-size:13px;padding:7px 14px;border-radius:var(--r-pill)}

/* ===== RESPONSIVE (home) ===== */
@media(max-width:1080px){
  .intro-grid{grid-template-columns:1fr}
  .gallery,.reels{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:780px){
  .cats{grid-template-columns:1fr}
  .gallery,.reels{grid-template-columns:repeat(2,1fr)}
  .states{grid-template-columns:repeat(3,1fr)}
  .hero-card{padding:32px}
  .section{padding:60px 0}
  .videos{padding:40px 22px}
}
@media(max-width:640px){
  .hero-card{min-height:420px}
  .what-card{padding:24px}
}
@media(max-width:480px){
  .gallery,.reels{grid-template-columns:1fr}
}
