/* ===== Moiztex Redesign — Index, Per-Fabric & Katalog layouts (kain.css) ===== */
/* Works with catalogue.css (tokens, topbar, search, modal, cart, controls) */

body.fabric-page,
body.index-page,
body.katalog-page{min-height:100vh;display:flex;flex-direction:column;}

/* =================================================================
   INDEX PAGE
   ================================================================= */

/* color strip atop hero */
.idx-strip{height:9px;display:flex;overflow:hidden;}
.idx-strip span{flex:1;}

.idx-hero{background:var(--sheet);border-bottom:1px solid var(--line);transition:background .35s ease;}
.idx-hero-inner{display:flex;align-items:center;gap:80px;max-width:1200px;margin:0 auto;padding:76px 60px 72px;}
.idx-hero-left{flex:0 0 54%;}
.idx-hero-sub{font-family:var(--font-body);font-size:9.5px;letter-spacing:.42em;text-transform:uppercase;
  color:var(--accent);font-weight:400;margin:0 0 24px;}
.idx-hero-title{font-family:var(--font-display);font-style:italic;font-size:clamp(64px, 6.2vw, 80px);font-weight:400;
  line-height:1.02;letter-spacing:-.015em;margin:0 0 40px;color:var(--ink);}
.idx-hero-stats{display:flex;align-items:center;gap:36px;margin-bottom:44px;}
.hero-stat-num{font-family:var(--font-display);font-size:48px;font-weight:400;line-height:1;color:var(--ink);}
.hero-stat-lbl{font-family:var(--font-body);font-size:9px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--muted);margin-top:5px;font-weight:300;}
.hero-stat-div{width:1px;height:40px;background:var(--line2);flex-shrink:0;}
.idx-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.idx-btn{font-family:var(--font-body);font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  text-decoration:none;padding:13px 28px;border-radius:2px;font-weight:500;white-space:nowrap;
  display:inline-flex;align-items:center;gap:8px;transition:transform .18s,opacity .18s,background .2s;}
.idx-btn:hover{transform:translateY(-2px);}
.idx-btn.primary{background:var(--ink);color:var(--bg);}
.idx-btn.ghost{color:var(--soft);font-weight:400;border:1px solid var(--line2);}
.idx-btn.ghost:hover{border-color:var(--accent);color:var(--accent);}
.idx-btn svg{width:11px;height:11px;}
.idx-hero-right{flex:1;display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(3,1fr);
  gap:5px;height:260px;}
.idx-hero-tile{border-radius:2px;overflow:hidden;background:var(--sw-bg);box-shadow:0 0 0 1px rgba(0,0,0,.05);}
.idx-hero-tile img{width:100%;height:100%;object-fit:cover;display:block;}

.idx-main{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:44px 40px 88px;}
.idx-section-head{display:flex;align-items:center;gap:20px;margin:0 0 36px;}
.idx-section-title{font-family:var(--font-body);font-size:9px;letter-spacing:.36em;text-transform:uppercase;
  color:var(--muted);font-weight:400;margin:0;white-space:nowrap;}
.idx-section-line{flex:1;height:1px;background:var(--line);}
.idx-count{font-family:var(--font-body);font-size:9px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);white-space:nowrap;font-weight:300;}

.idx-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:36px 20px;}

/* portrait fabric cards */
.fab-card{display:block;text-decoration:none;color:var(--ink);transition:transform .28s ease;}
.fab-card:hover{transform:translateY(-8px);}
.fab-card-img{position:relative;aspect-ratio:3/4;border-radius:3px;overflow:hidden;
  background:var(--sw-bg);margin:0 0 12px;box-shadow:0 4px 16px rgba(70,52,28,.08);}
.fab-card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease;}
.fab-card:hover .fab-card-img img{transform:scale(1.05);}
.fab-card-num{display:none;}
.fab-card-flag{position:absolute;top:10px;right:10px;z-index:2;background:var(--accent);color:var(--accent-fg);
  font-family:var(--font-body);font-size:7.5px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  padding:4px 9px;border-radius:2px;line-height:1;}
.fab-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(16,12,8,.82) 0%,transparent 52%);
  display:flex;flex-direction:column;justify-content:flex-end;padding:14px;opacity:0;transition:opacity .3s ease;}
.fab-card:hover .fab-card-overlay{opacity:1;}
.fab-card-overlay .ov-name{color:rgba(253,250,245,.95);font-family:var(--font-display);font-size:18px;
  font-style:italic;font-weight:400;line-height:1.2;}
.fab-card-overlay .ov-count{color:rgba(253,250,245,.5);font-family:var(--font-body);font-size:8px;
  letter-spacing:.22em;text-transform:uppercase;margin-top:5px;font-weight:300;}
.fab-card-info{padding:0 2px;}
.fab-card-name{font-family:var(--font-display);font-size:20px;font-weight:400;font-style:italic;
  line-height:1.2;display:block;color:var(--ink);}
.fab-card-count{font-family:var(--font-body);font-size:9px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);display:block;margin-top:5px;font-weight:300;}
.fab-card-price{font-family:var(--font-body);font-size:11px;font-weight:500;color:var(--accent);
  display:block;margin-top:6px;letter-spacing:.01em;}

/* =================================================================
   PER-FABRIC PAGE
   ================================================================= */
.fab-hero{background:var(--sheet);border-bottom:2px solid var(--line);}
.fab-hero-inner{display:flex;max-width:1100px;margin:0 auto;min-height:360px;}
.fab-hero-swatch{flex:0 0 36%;position:relative;overflow:hidden;background:var(--sw-bg);}
.fab-hero-swatch img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;}
.fab-hero-num{display:none;}
.fab-hero-info{flex:1;padding:44px 52px;display:flex;flex-direction:column;justify-content:center;}
.kain-eyebrow{font-family:var(--font-body);font-size:9px;letter-spacing:.36em;text-transform:uppercase;
  color:var(--muted);margin:0 0 10px;font-weight:400;}
.kain-title{font-family:var(--font-display);font-style:italic;font-size:62px;font-weight:400;
  margin:0 0 6px;line-height:1;color:var(--ink);}
.kain-lookbook{font-family:var(--font-body);font-size:12.5px;color:var(--soft);margin:0 0 24px;
  font-weight:300;line-height:1.65;max-width:400px;}
.specs-row{display:flex;margin-bottom:28px;border:1px solid var(--line);border-radius:2px;overflow:hidden;}
.specs-row .spec{flex:1;padding:12px 16px;}
.specs-row .spec+.spec{border-left:1px solid var(--line);}
.specs-row .spec.narrow{flex:0 0 100px;}
.spec dt,.spec-k{font-family:var(--font-body);font-size:8px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);margin:0 0 4px;font-weight:400;}
.spec dd,.spec-v{font-family:var(--font-body);font-size:11.5px;color:var(--ink);font-weight:400;
  margin:0;line-height:1.4;}
.kain-price{display:flex;align-items:baseline;gap:10px;margin:0 0 24px;}
.kain-price-k{font-family:var(--font-body);font-size:8px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);font-weight:400;}
.kain-price-v{font-family:var(--font-body);font-size:21px;font-weight:500;color:var(--accent);
  line-height:1;letter-spacing:.01em;}
.kain-cta-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.kain-cta{font-family:var(--font-body);font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  background:var(--ink);color:var(--bg);border:none;padding:13px 24px;border-radius:2px;cursor:pointer;
  font-weight:500;white-space:nowrap;display:inline-flex;align-items:center;gap:8px;transition:transform .15s;}
.kain-cta:hover{transform:translateY(-2px);}
.kain-cta svg{width:12px;height:12px;animation:ctaArrowBob 1.7s ease-in-out infinite;}
.kain-cta:hover svg{animation-play-state:paused;}
@keyframes ctaArrowBob{0%,55%,100%{transform:translateY(0);}28%{transform:translateY(3px);}}
@media (prefers-reduced-motion:reduce){.kain-cta svg{animation:none;}}
.kain-badge{font-family:var(--font-body);font-size:9.5px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--accent);font-weight:400;white-space:nowrap;padding:7px 16px;border:1px solid var(--accent);
  border-radius:2px;flex-shrink:0;}

.kain-main{flex:1;max-width:1100px;width:100%;margin:0 auto;padding:36px 40px 88px;}

/* fabric sub-tabs (Lookbook / Komposisi) */
.fab-tabs{display:flex;gap:0;margin-bottom:32px;border-bottom:2px solid var(--line);}
.fab-tab{font-family:var(--font-body);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  font-weight:400;padding:14px 24px;border:none;background:none;color:var(--muted);cursor:pointer;
  border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .18s,border-color .18s;}
.fab-tab:hover{color:var(--soft);}
.fab-tab.active{color:var(--ink);border-bottom-color:var(--ink);}
.fab-pane{display:none;}
.fab-pane.active{display:block;}

/* Komposisi table */
.komp-table{max-width:540px;border:1px solid var(--line);border-radius:2px;overflow:hidden;
  display:grid;grid-template-columns:150px 1fr;}
.komp-table .k{padding:14px 18px;background:var(--sw-bg);border-bottom:1px solid var(--line);
  font-family:var(--font-body);font-size:8.5px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);font-weight:400;}
.komp-table .v{padding:14px 18px;border-bottom:1px solid var(--line);font-family:var(--font-body);
  font-size:13px;color:var(--ink);font-weight:300;}
.komp-table .k:nth-last-child(2),.komp-table .v:last-child{border-bottom:none;}
.komp-note{font-family:var(--font-body);font-size:10.5px;color:var(--muted);margin:14px 0 0;
  font-weight:300;font-style:italic;}

/* Lookbook pane — placeholder image cards (tells owner what photo to add) */
.lookbook-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:28px;}
.lb-ph{border:1.5px dashed var(--line2);border-radius:3px;background:var(--sw-bg);
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  padding:28px 24px;min-height:172px;transition:border-color .2s,background .2s;}
.lb-ph:hover{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 5%,var(--sw-bg));}
.lb-ph-main{grid-row:span 2;min-height:360px;}
.lb-ph-ico{width:42px;height:42px;color:var(--muted);margin-bottom:14px;opacity:.8;}
.lb-ph-ico svg{width:100%;height:100%;}
.lb-ph-tag{font-family:var(--font-body);font-size:8px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--accent);font-weight:500;margin-bottom:8px;}
.lb-ph-title{font-family:var(--font-display);font-style:italic;font-size:20px;color:var(--soft);
  line-height:1.25;margin-bottom:9px;}
.lb-ph-hint{font-family:var(--font-body);font-size:10.5px;color:var(--muted);font-weight:300;
  line-height:1.55;max-width:240px;}

/* Lookbook pane — actual editorial photos */
.lb-photo{border-radius:3px;overflow:hidden;min-height:172px;}
.lb-photo img{width:100%;height:100%;object-fit:cover;display:block;}
.lb-photo-main{grid-row:span 2;min-height:360px;}

/* Lookbook pane */
.lookbook-lead{font-family:var(--font-body);font-size:13px;line-height:1.8;color:var(--soft);
  margin:0;font-weight:300;max-width:620px;}
.lookbook-cta{font-family:var(--font-body);font-size:11.5px;line-height:1.75;color:var(--soft);
  margin:24px 0 0;font-weight:300;max-width:560px;border-top:1px solid var(--line);padding-top:20px;}

/* swatch section */
.warna-section{margin-top:48px;padding-top:32px;border-top:1px solid var(--line);}
.warna-head{display:flex;align-items:center;gap:20px;margin-bottom:24px;}
.warna-head h2{font-family:var(--font-body);font-size:9px;letter-spacing:.36em;text-transform:uppercase;
  color:var(--muted);font-weight:400;margin:0;white-space:nowrap;}
.warna-head .line{flex:1;height:1px;background:var(--line);}
.warna-head .hint{font-family:var(--font-body);font-size:9px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--muted);white-space:nowrap;font-weight:300;}
.kain-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:20px 14px;}

/* =================================================================
   KATALOG LENGKAP (list page)
   ================================================================= */
.katalog-main{flex:1;max-width:960px;width:100%;margin:0 auto;padding:52px 40px 88px;}
.katalog-head{margin-bottom:48px;padding-bottom:28px;border-bottom:2px solid var(--ink);}
.katalog-head .eyebrow{font-family:var(--font-body);font-size:9px;letter-spacing:.38em;text-transform:uppercase;
  color:var(--accent);font-weight:400;margin:0 0 16px;}
.katalog-head h1{font-family:var(--font-display);font-style:italic;font-size:72px;font-weight:400;
  margin:0 0 10px;line-height:1;color:var(--ink);}
.katalog-head .meta{font-family:var(--font-body);font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--muted);margin:0;font-weight:300;}
.katalog-group{margin-bottom:40px;}
.katalog-group-name{font-family:var(--font-body);font-size:8.5px;letter-spacing:.38em;text-transform:uppercase;
  color:var(--accent);font-weight:500;margin:0 0 4px;}
.katalog-row{display:flex;align-items:center;gap:16px;padding:13px 8px;border-bottom:1px solid var(--line);
  text-decoration:none;color:var(--ink);border-radius:2px;transition:background .15s,padding .15s;}
.katalog-row:hover{background:color-mix(in srgb,var(--accent) 8%,transparent);padding-left:14px;}
.katalog-row .num{display:none;}
.katalog-row .name{font-family:var(--font-display);font-style:italic;font-size:26px;font-weight:400;
  flex:1;line-height:1;color:var(--ink);}
.katalog-row .chips{display:flex;gap:3px;flex-shrink:0;align-items:center;}
.katalog-row .chips span{width:14px;height:14px;border-radius:2px;box-shadow:0 0 0 1px rgba(0,0,0,.08);flex-shrink:0;}
.katalog-row .cnt{font-family:var(--font-body);font-size:9px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--muted);white-space:nowrap;flex-shrink:0;font-weight:300;min-width:72px;text-align:right;}
.katalog-row .arr{width:12px;height:12px;color:var(--line2);flex-shrink:0;}

/* =================================================================
   RESPONSIVE
   ================================================================= */
@media (max-width:1020px){
  .idx-hero-right{display:none;}
  .idx-hero-left{flex:1 1 100%;}
  .idx-hero-inner{padding:64px 40px 60px;}
  .idx-hero-title{font-size:80px;}
  .idx-grid{grid-template-columns:repeat(3,1fr);}
  .fab-hero-inner{flex-direction:column;min-height:auto;}
  .fab-hero-swatch{flex:none;height:220px;}
  .kain-grid{grid-template-columns:repeat(5,1fr);}
}
@media (max-width:680px){
  .idx-hero-inner{padding:48px 22px 44px;}
  .idx-hero-title{font-size:54px;}
  .idx-hero-stats{gap:24px;margin-bottom:32px;}
  .hero-stat-num{font-size:36px;}
  .idx-actions{flex-direction:column;align-items:stretch;gap:10px;}
  .idx-btn{justify-content:center;}
  .idx-main,.kain-main,.katalog-main{padding:28px 20px 72px;}
  .idx-grid{grid-template-columns:repeat(2,1fr);gap:24px 12px;}
  .idx-section-head{gap:12px;}
  .fab-hero-info{padding:28px 24px;}
  .kain-lookbook{font-size:14px;font-weight:400;}
  .kain-title{font-size:44px;}
  .specs-row{flex-direction:column;}
  .specs-row .spec.narrow{flex:auto;}
  .specs-row .spec+.spec{border-left:none;border-top:1px solid var(--line);}
  .kain-grid{grid-template-columns:repeat(3,1fr);gap:12px;}
  .lookbook-grid{grid-template-columns:1fr;}
  .lb-ph-main{grid-row:auto;min-height:200px;}
  .lb-photo-main{grid-row:auto;min-height:200px;}
  .katalog-head h1{font-size:44px;}
  .katalog-row .name{font-size:20px;}
  .katalog-row .chips{display:none;}
  .komp-table{grid-template-columns:120px 1fr;}
}
@media (max-width:420px){
  .idx-grid{grid-template-columns:repeat(2,1fr);}
  .idx-hero-title{font-size:44px;}
  .kain-grid{grid-template-columns:repeat(3,1fr);}
}
