@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

:root{
  --bg: #000;
  --fg: #fff;
  --muted: rgba(255,255,255,.72);
  --muted2: rgba(255,255,255,.52);
  --line: rgba(255,255,255,.13);
  --panel: rgba(255,255,255,.055);
  --panel2: rgba(255,255,255,.09);
  --glass: rgba(255,255,255,.07);
  --glass2: rgba(255,255,255,.12);
  --focus: rgba(255,255,255,.9);
  --accent: #D4A853;
  --accent-dim: rgba(212,168,83,.18);
  --accent-glow: rgba(212,168,83,.35);
  --max: 1120px;
}

*{ box-sizing: border-box; margin: 0; padding: 0; }
html{ scroll-behavior: smooth; }
html, body{ height: 100%; }
body{
  font-family: 'Inter', Arial, Helvetica, sans-serif;
  background: var(--bg);
  color: var(--fg);
  line-height: 1.55;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

a{ color: var(--fg); text-decoration: none; }
a:hover{ text-decoration: underline; }

.container{
  width: min(var(--max), calc(100% - 2rem));
  margin: 0 auto;
}

.skip-link{
  position: absolute;
  left: -9999px;
  top: 0;
  padding: .75rem 1rem;
  background: #fff;
  color: #000;
  z-index: 9999;
}
.skip-link:focus{ left: 1rem; top: 1rem; outline: 2px solid #000; }

/* ─── HEADER ─── */
.site-header{
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(0,0,0,.82);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border-bottom: 1px solid var(--line);
  transition: background 0.3s ease, border-color 0.3s ease;
}
.header-inner{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .85rem 0;
}
.brand{ display: grid; gap: .1rem; }
.brand-mark{
  font-weight: 800;
  letter-spacing: .06em;
  font-size: 1.05rem;
}
.brand-mark span{
  font-weight: 400;
  opacity: .7;
  margin-left: .3rem;
  letter-spacing: .02em;
}
.brand-sub{
  font-size: .78rem;
  color: var(--accent);
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 500;
}
.nav{ display: flex; align-items: center; gap: .75rem; }
.nav-toggle{
  display: none;
  border: 1px solid var(--line);
  background: transparent;
  color: var(--fg);
  padding: .5rem .75rem;
  border-radius: .5rem;
  cursor: pointer;
  font-size: 1rem;
}
.nav-toggle:focus{ outline: 2px solid var(--focus); outline-offset: 2px; }
.nav-list{
  list-style: none;
  display: flex;
  gap: .5rem;
  padding: 0;
}
.nav-list a{
  display: inline-block;
  padding: .38rem .6rem;
  border-radius: .5rem;
  color: var(--muted2);
  font-size: .88rem;
  font-weight: 500;
  letter-spacing: .01em;
  transition: color 0.2s, background 0.2s;
}
.nav-list a:hover{ color: var(--fg); background: var(--panel); text-decoration: none; }
.nav-list a.active{
  color: var(--fg);
  background: var(--glass);
  border: 1px solid rgba(255,255,255,.15);
}
.nav-list a.nav-sister{
  color: var(--accent);
  border: 1px solid rgba(212,168,83,.3);
  border-radius: .5rem;
  padding: .35rem .6rem;
}
.nav-list a.nav-sister:hover{
  background: var(--accent-dim);
  text-decoration: none;
}

/* ─── HERO ─── */
.hero-overlay{
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(0,0,0,.88) 0%,
    rgba(0,0,0,.72) 50%,
    rgba(0,0,0,.65) 100%
  );
  pointer-events: none;
}
.hero{
  padding: 6rem 0 4rem;
  border-bottom: 1px solid var(--line);
  overflow: hidden;
  position: relative;
}
.hero::before{
  content: '';
  position: absolute;
  top: -50%;
  left: -10%;
  width: 70%;
  height: 200%;
  background: radial-gradient(ellipse, rgba(212,168,83,.04) 0%, transparent 65%);
  pointer-events: none;
  animation: pulse 8s ease-in-out infinite;
}
.hero-inner{ display: grid; gap: 1.75rem; }
.hero h1{
  font-size: clamp(2.6rem, 6vw, 4.8rem);
  line-height: 1.03;
  letter-spacing: -0.04em;
  font-weight: 800;
}
.hero-word{
  display: inline-block;
  opacity: 0;
  transform: translateY(40px);
  animation: wordFadeUp 0.6s ease-out forwards;
}
.lead{
  font-size: 1.15rem;
  color: var(--muted);
  max-width: 65ch;
  opacity: 0;
  animation: fadeInUp 0.7s ease-out 0.5s forwards;
}
.cta-row{
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  opacity: 0;
  animation: fadeInUp 0.7s ease-out 0.7s forwards;
}
.hero-cards{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1rem;
}

/* ─── PAGE HERO ─── */
.page-hero{
  padding: 4rem 0 2rem;
  border-bottom: 1px solid var(--line);
  overflow: hidden;
}
.page-hero h1{
  font-size: clamp(2.5rem, 5vw, 4rem);
  letter-spacing: -0.03em;
  line-height: 1.05;
}
.page-hero .lead{
  animation: fadeInUp 0.7s ease-out 0.3s forwards;
}

/* ─── SECTIONS ─── */
.section{ padding: 3rem 0; }
.section-muted{
  background: linear-gradient(to bottom, rgba(255,255,255,.02), rgba(255,255,255,.03));
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.section-dark{
  background: rgba(255,255,255,.03);
}

h2{
  font-size: clamp(1.9rem, 3vw, 2.6rem);
  letter-spacing: -0.03em;
  font-weight: 700;
  margin-bottom: 0.75rem;
  line-height: 1.15;
}
h3{ font-size: 1.05rem; font-weight: 600; margin-bottom: .45rem; }
p{ margin-bottom: 1rem; color: var(--muted); line-height: 1.65; }
strong{ color: var(--fg); font-weight: 600; }

/* ─── BUTTONS ─── */
.btn{
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .72rem 1.35rem;
  border-radius: .75rem;
  border: 1px solid var(--fg);
  background: var(--fg);
  color: #000;
  font-weight: 700;
  font-size: .9rem;
  letter-spacing: .01em;
  text-decoration: none;
  transition: filter 0.2s, transform 0.2s, box-shadow 0.2s;
}
.btn:hover{ filter: brightness(.92); transform: translateY(-2px); text-decoration: none; box-shadow: 0 8px 24px rgba(255,255,255,.12); }
.btn:focus{ outline: 2px solid var(--focus); outline-offset: 2px; }
.btn-accent{
  background: var(--accent);
  border-color: var(--accent);
  color: #000;
}
.btn-accent:hover{ box-shadow: 0 8px 28px var(--accent-glow); }
.btn-ghost{
  background: transparent;
  color: var(--fg);
  border: 1px solid rgba(255,255,255,.2);
  font-weight: 500;
}
.btn-ghost:hover{ background: var(--glass); border-color: rgba(255,255,255,.35); filter: none; }

/* ─── CARDS ─── */
.card{
  border: 1px solid var(--line);
  background: var(--glass);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: 1.1rem;
  padding: 1.35rem;
  transition: border-color 0.3s, background 0.3s, transform 0.3s, box-shadow 0.3s;
}
.card:hover{
  border-color: rgba(255,255,255,.28);
  background: var(--glass2);
  transform: translateY(-5px);
  box-shadow: 0 16px 40px rgba(0,0,0,.5);
}

/* ─── GRIDS ─── */
.grid-2{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  align-items: start;
}
.grid-3{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  align-items: start;
}
.grid-4{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
  align-items: start;
}

/* ─── PANEL LINKS ─── */
.panel-link-tag{
  display: inline-block;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: .6rem;
}
.panel-link{
  display: block;
  border: 1px solid var(--line);
  background: var(--glass);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-radius: 1.1rem;
  padding: 1.35rem;
  text-decoration: none;
  transition: background 0.3s, border-color 0.3s, transform 0.3s, box-shadow 0.3s;
}
.panel-link:hover{ background: var(--glass2); text-decoration: none; border-color: rgba(255,255,255,.28); transform: translateY(-5px); box-shadow: 0 12px 32px rgba(0,0,0,.45); }

/* ─── UTILITY ─── */
.clean-list{
  margin: .5rem 0 0;
  padding-left: 1.15rem;
  color: var(--muted);
}
.clean-list li{ margin: .4rem 0; }
.pill-row{ display: flex; flex-wrap: wrap; gap: .5rem; margin: .75rem 0 1rem; }
.pill{
  display: inline-flex;
  padding: .25rem .65rem;
  border-radius: 999px;
  border: 1px solid var(--line);
  color: var(--muted);
  font-size: .85rem;
}
.note{
  margin-top: 1.25rem;
  padding: 1rem;
  border-radius: .9rem;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.04);
  color: var(--muted);
}

/* ─── FORMS ─── */
.form{ margin-top: 1rem; display: grid; gap: 1rem; }
label{ display: grid; gap: .4rem; color: var(--muted); font-size: .95rem; }
input, select, textarea{
  width: 100%;
  padding: .7rem .75rem;
  border-radius: .75rem;
  border: 1px solid var(--line);
  background: rgba(0,0,0,.4);
  color: var(--fg);
  font-family: inherit;
  font-size: 1rem;
  transition: border-color 0.3s, outline 0.3s;
}
input:focus, select:focus, textarea:focus{
  outline: 2px solid var(--focus);
  outline-offset: 2px;
  border-color: var(--muted);
}
.form-row{ display: flex; flex-wrap: wrap; gap: .75rem; align-items: center; }
.form-hint{ margin: 0; min-height: 1.2em; color: var(--muted2); }

/* ─── PORTFOLIO ─── */
.portfolio-item{
  border: 1px solid var(--line);
  background: var(--panel);
  border-radius: 1rem;
  overflow: hidden;
  display: grid;
  grid-template-columns: 220px 1fr;
  transition: border-color 0.3s, background 0.3s;
}
.portfolio-item:hover{ border-color: var(--muted); background: var(--panel2); }
.portfolio-thumb{
  background: linear-gradient(135deg, rgba(255,255,255,.12), rgba(255,255,255,.04));
  min-height: 160px;
  background-size: cover;
  background-position: center;
}
.portfolio-body{ padding: 1rem; }
.meta{ display: flex; flex-wrap: wrap; gap: .5rem; margin-top: .75rem; }

/* ─── GALLERY PAGE ─── */
.gallery-filter{
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin: 1.5rem 0;
}
.filter-btn{
  padding: .35rem .8rem;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: transparent;
  color: var(--muted);
  font-family: inherit;
  font-size: .9rem;
  cursor: pointer;
  transition: all 0.2s;
}
.filter-btn:hover{ border-color: var(--muted); color: var(--fg); }
.filter-btn.active{ background: var(--fg); color: #000; border-color: var(--fg); font-weight: 700; }

.gallery-grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
  gap: 1.5rem;
  margin-top: 1rem;
}
.gallery-item{
  border: 1px solid var(--line);
  background: var(--panel);
  border-radius: 1rem;
  overflow: hidden;
  cursor: pointer;
  transition: border-color 0.3s, background 0.3s, transform 0.3s;
}
.gallery-item:hover{
  border-color: rgba(255,255,255,.4);
  background: var(--panel2);
  transform: translateY(-8px);
}
.gallery-item[data-hidden="true"]{ display: none; }

.gallery-thumb{
  width: 100%;
  height: 220px;
  background: linear-gradient(135deg, rgba(255,255,255,.1), rgba(255,255,255,.03));
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  background-size: cover;
  background-position: center;
}
.gallery-thumb::after{
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 50%, rgba(0,0,0,.5));
  opacity: 0;
  transition: opacity 0.3s;
}
.gallery-item:hover .gallery-thumb::after{ opacity: 1; }

.placeholder-label{
  color: var(--muted2);
  font-size: .85rem;
  text-align: center;
  padding: 1rem;
}
.gallery-body{ padding: 1rem; }
.gallery-body h3{ font-size: 1rem; margin-bottom: .4rem; }
.gallery-desc{ font-size: .9rem; color: var(--muted2); margin: 0 0 .75rem; }
.gallery-tags{ display: flex; flex-wrap: wrap; gap: .4rem; }
.gallery-tag{
  font-size: .78rem;
  padding: .15rem .5rem;
  border-radius: 999px;
  border: 1px solid var(--line);
  color: var(--muted2);
}

/* ─── MODAL ─── */
.modal{
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.96);
  z-index: 200;
  align-items: center;
  justify-content: center;
  padding: 2rem;
}
.modal.open{ display: flex; animation: fadeIn 0.25s ease-out; }
.modal-inner{
  background: #111;
  border: 1px solid var(--line);
  border-radius: 1.25rem;
  max-width: 780px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  position: relative;
  animation: scaleIn 0.3s ease-out;
}
.modal-close{
  position: sticky;
  top: 0;
  float: right;
  margin: 1rem;
  background: rgba(255,255,255,.1);
  border: 1px solid var(--line);
  color: var(--fg);
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 1.2rem;
  transition: background 0.2s;
  z-index: 10;
}
.modal-close:hover{ background: rgba(255,255,255,.2); }
.modal-thumb{
  width: 100%;
  height: 300px;
  background: linear-gradient(135deg, rgba(255,255,255,.1), rgba(255,255,255,.03));
  background-size: cover;
  background-position: center;
}
.modal-body{ padding: 1.5rem; }
.modal-body h2{ margin-bottom: .75rem; }
.modal-body p{ color: var(--muted); }
.modal-meta{ display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1rem; }

/* ─── COURSE MATERIALS ─── */
.module-list{ display: grid; gap: 1rem; margin-top: 1rem; }
.module-item{
  border: 1px solid var(--line);
  background: var(--panel);
  border-radius: 1rem;
  overflow: hidden;
}
.module-header{
  padding: 1rem 1.25rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  user-select: none;
  transition: background 0.2s;
}
.module-header:hover{ background: var(--panel2); }
.module-title{ font-size: 1rem; font-weight: 700; }
.module-week{ font-size: .85rem; color: var(--muted2); }
.module-chevron{
  transition: transform 0.3s;
  color: var(--muted2);
  font-size: 1.2rem;
}
.module-item.open .module-chevron{ transform: rotate(180deg); }
.module-body{
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease;
  border-top: 0px solid var(--line);
}
.module-item.open .module-body{
  max-height: 600px;
  border-top: 1px solid var(--line);
}
.module-content{ padding: 1.25rem; }

.resource-list{ display: grid; gap: .5rem; margin-top: .75rem; }
.resource-item{
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .65rem .9rem;
  border-radius: .75rem;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.03);
  transition: background 0.2s, border-color 0.2s;
}
.resource-item:hover{ background: var(--panel2); border-color: var(--muted); }
.resource-icon{ font-size: 1.1rem; flex-shrink: 0; }
.resource-label{ color: var(--muted); font-size: .95rem; flex: 1; }
.resource-status{
  font-size: .78rem;
  padding: .2rem .55rem;
  border-radius: 999px;
  border: 1px solid var(--line);
}
.status-available{ border-color: rgba(100,255,100,.3); color: rgba(100,255,100,.8); }
.status-soon{ border-color: var(--line); color: var(--muted2); }

/* ─── WEEK-TAB SYSTEM ─── */
.course-tab-switcher{
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
  margin-bottom: 2rem;
}
.course-tab-btn{
  padding: .55rem 1.25rem;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--muted);
  font-size: .9rem;
  cursor: pointer;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.course-tab-btn:hover{ background: var(--panel2); color: var(--fg); }
.course-tab-btn.active{
  background: var(--fg);
  color: var(--bg);
  border-color: var(--fg);
  font-weight: 700;
}

.week-tabs-nav{
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  margin-bottom: 1.75rem;
}
.week-tab-btn{
  width: 2.6rem;
  height: 2.6rem;
  border-radius: .6rem;
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--muted);
  font-size: .85rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
}
.week-tab-btn:hover{ background: var(--panel2); color: var(--fg); }
.week-tab-btn.active{
  background: var(--fg);
  color: var(--bg);
  border-color: var(--fg);
}

.week-panel{ display: none; }
.week-panel.active{ display: block; }

.week-hero{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  margin-bottom: 2rem;
  align-items: start;
}
@media(max-width:700px){ .week-hero{ grid-template-columns: 1fr; } }

.week-header-text{}
.week-label{
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted2);
  margin-bottom: .4rem;
}
.week-title{
  font-size: 1.6rem;
  font-weight: 700;
  margin-bottom: .75rem;
  line-height: 1.25;
}
.week-subtitle{
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.6;
  margin-bottom: 1rem;
}

.week-objectives{
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: .5rem;
}
.week-objectives li{
  display: flex;
  align-items: flex-start;
  gap: .6rem;
  font-size: .95rem;
  color: var(--muted);
}
.week-objectives li::before{
  content: '→';
  color: var(--fg);
  font-weight: 700;
  flex-shrink: 0;
  margin-top: .05em;
}

/* media placeholder */
.media-block{
  border: 2px dashed var(--line);
  border-radius: 1rem;
  background: var(--panel);
  aspect-ratio: 16/9;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .6rem;
  text-align: center;
  padding: 1.5rem;
  color: var(--muted2);
  position: relative;
  overflow: hidden;
}
.media-block iframe,
.media-block video{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border-radius: 1rem;
  border: none;
}
.media-block-icon{ font-size: 2.5rem; line-height: 1; }
.media-block-title{ font-size: .95rem; font-weight: 600; color: var(--muted); }
.media-block-sub{ font-size: .8rem; color: var(--muted2); }

.week-session-plan{
  margin-top: 1.5rem;
  border: 1px solid var(--line);
  border-radius: 1rem;
  overflow: hidden;
}
.week-session-header{
  padding: .9rem 1.25rem;
  background: var(--panel);
  font-weight: 700;
  font-size: .9rem;
  border-bottom: 1px solid var(--line);
}
.week-session-steps{
  list-style: none;
  padding: 0;
  margin: 0;
}
.week-session-steps li{
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: .85rem 1.25rem;
  border-bottom: 1px solid var(--line);
  font-size: .9rem;
  color: var(--muted);
}
.week-session-steps li:last-child{ border-bottom: none; }
.step-num{
  width: 1.6rem;
  height: 1.6rem;
  border-radius: 50%;
  background: var(--panel2);
  border: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .78rem;
  font-weight: 700;
  flex-shrink: 0;
  color: var(--fg);
}

.module-item.open .module-body{ max-height: 1200px; }

/* ─── PARALLAX / SCROLL ANIMATIONS ─── */
.parallax-bg{
  position: relative;
  overflow: hidden;
}
.parallax-bg::before{
  content: '';
  position: absolute;
  inset: -20%;
  background: inherit;
  will-change: transform;
}

/* Animate on scroll */
.aos{
  opacity: 0;
  transition: opacity 0.7s ease-out, transform 0.7s ease-out;
}
.aos[data-aos="fade-up"]{
  transform: translateY(40px);
}
.aos[data-aos="fade-left"]{
  transform: translateX(-40px);
}
.aos[data-aos="fade-right"]{
  transform: translateX(40px);
}
.aos[data-aos="scale"]{
  transform: scale(0.93);
}
.aos[data-aos="fade"]{
  transform: none;
}
.aos.visible{
  opacity: 1;
  transform: none;
}
.aos[data-delay="100"]{ transition-delay: 0.1s; }
.aos[data-delay="200"]{ transition-delay: 0.2s; }
.aos[data-delay="300"]{ transition-delay: 0.3s; }
.aos[data-delay="400"]{ transition-delay: 0.4s; }
.aos[data-delay="500"]{ transition-delay: 0.5s; }

/* Marquee */
.marquee-wrap{
  overflow: hidden;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 0.85rem 0;
  background: rgba(212,168,83,.03);
}
.marquee-track{
  display: flex;
  gap: 3rem;
  animation: marquee 26s linear infinite;
  white-space: nowrap;
  will-change: transform;
}
.marquee-track span{
  color: var(--muted2);
  font-size: .78rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  flex-shrink: 0;
  font-weight: 500;
}
.marquee-track span.sep{
  color: var(--accent);
  opacity: .55;
}

/* Scroll progress bar */
.scroll-progress{
  position: fixed;
  top: 0;
  left: 0;
  height: 2px;
  background: linear-gradient(to right, var(--accent), #fff);
  z-index: 999;
  width: 0%;
  transition: width 0.1s;
}

/* ─── FOOTER ─── */
.site-footer{
  border-top: 1px solid var(--line);
  padding: 2.5rem 0;
  background: linear-gradient(to bottom, rgba(212,168,83,.03), rgba(0,0,0,0));
}
.footer-inner{
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  align-items: center;
  justify-content: space-between;
}
.footer-brand{ font-weight: 800; letter-spacing: .08em; font-size: 1.05rem; }
.footer-muted{ color: var(--muted2); font-size: .95rem; }
.footer-links{ display: flex; gap: 1.25rem; }
.footer-links a{ color: var(--muted); transition: color 0.2s; }
.footer-links a:hover{ color: var(--fg); text-decoration: none; }

/* ─── HORIZONTAL SCROLL PORTFOLIO ─── */
.horizontal-portfolio{ overflow-x: auto; padding-bottom: 1rem; -webkit-overflow-scrolling: touch; }
.horizontal-scroll{
  display: flex;
  gap: 1.5rem;
  padding: 0.5rem 0;
}
.h-item{
  flex-shrink: 0;
  width: 300px;
  border: 1px solid var(--line);
  background: var(--panel);
  border-radius: 1rem;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color 0.3s, transform 0.3s;
}
.h-item:hover{ border-color: var(--muted); transform: translateY(-4px); }
.h-thumb{
  background: linear-gradient(135deg, rgba(255,255,255,.12), rgba(255,255,255,.04));
  height: 180px;
  background-size: cover;
  background-position: center;
}
.h-body{ padding: 1rem; }

/* ─── KEYFRAMES ─── */
@keyframes fadeInUp{
  from{ opacity: 0; transform: translateY(30px); }
  to{ opacity: 1; transform: translateY(0); }
}
@keyframes wordFadeUp{
  from{ opacity: 0; transform: translateY(40px); }
  to{ opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn{
  from{ opacity: 0; }
  to{ opacity: 1; }
}
@keyframes scaleIn{
  from{ opacity: 0; transform: scale(0.95); }
  to{ opacity: 1; transform: scale(1); }
}
@keyframes marquee{
  from{ transform: translateX(0); }
  to{ transform: translateX(-50%); }
}
@keyframes pulse{
  0%, 100%{ opacity: 1; transform: scale(1); }
  50%{ opacity: 0.5; transform: scale(1.05); }
}
@keyframes float{
  0%, 100%{ transform: translateY(0); }
  50%{ transform: translateY(-10px); }
}

/* ─── RESPONSIVE ─── */
@media (max-width: 860px){
  .hero-cards{ grid-template-columns: 1fr; }
  .grid-2{ grid-template-columns: 1fr; }
  .grid-3{ grid-template-columns: 1fr; }
  .grid-4{ grid-template-columns: repeat(2, 1fr); }
  .portfolio-item{ grid-template-columns: 1fr; }
}
@media (max-width: 600px){
  .grid-4{ grid-template-columns: 1fr; }
}
@media (max-width: 720px){
  .nav-toggle{ display: inline-block; }
  .nav-list{
    display: none;
    position: absolute;
    right: 1rem;
    top: 4.2rem;
    flex-direction: column;
    gap: .25rem;
    padding: .5rem;
    border: 1px solid var(--line);
    background: rgba(0,0,0,.95);
    border-radius: .9rem;
    min-width: 200px;
  }
  .nav-list.open{ display: flex; animation: fadeIn 0.2s ease-out; }
  .nav-list a{ padding: .6rem .75rem; }
}
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* ─── SECTION LABEL (eyebrow text) ─── */
.section-label{
  font-size: .72rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: .6rem;
  font-weight: 600;
}

/* ─── ABOUT EXPANDED ─── */
.about-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: start;
  margin-top: 2rem;
}
.about-image-block{
  border: 1px solid var(--line);
  border-radius: 1.25rem;
  background: var(--panel);
  min-height: 300px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  position: relative;
}
.about-image-block img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.about-placeholder{
  color: var(--muted2);
  font-size: .85rem;
  text-align: center;
  padding: 2rem;
}
.founder-quote{
  margin-top: 1.25rem;
  padding: 1.1rem 1.35rem;
  border-left: 2px solid var(--accent);
  background: var(--accent-dim);
  border-radius: 0 .75rem .75rem 0;
}
.founder-quote blockquote{
  font-size: 1.05rem;
  color: var(--muted);
  font-style: italic;
  margin: 0;
  line-height: 1.65;
}
@media (max-width: 860px){
  .about-grid{ grid-template-columns: 1fr; gap: 2rem; }
}

/* ─── STATS STRIP ─── */
.stats-strip{
  padding: 3rem 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: linear-gradient(to right, rgba(212,168,83,.04), rgba(0,0,0,0), rgba(212,168,83,.04));
}
.stat-item{ text-align: center; padding: 1rem; }
.stat-num{
  font-size: clamp(2.8rem, 5vw, 4.2rem);
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--accent);
}
.stat-label{
  font-size: .75rem;
  color: var(--muted2);
  margin-top: .5rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  font-weight: 500;
}

/* ─── FEATURED HORIZONTAL STRIP ─── */
.featured-strip{
  overflow-x: auto;
  padding-bottom: 1rem;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--line) transparent;
}
.featured-scroll{ display: flex; gap: 1.25rem; padding: .5rem 0; }
.featured-item{
  flex-shrink: 0;
  width: 240px;
  border: 1px solid var(--line);
  background: var(--panel);
  border-radius: 1rem;
  overflow: hidden;
  text-decoration: none;
  display: block;
  transition: border-color 0.3s, transform 0.3s;
}
.featured-item:hover{ border-color: rgba(255,255,255,.35); transform: translateY(-4px); text-decoration: none; }
.featured-thumb{
  height: 160px;
  background: linear-gradient(135deg, rgba(255,255,255,.12), rgba(255,255,255,.04));
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--muted2);
  font-size: 2rem;
}
.featured-body{ padding: .85rem; }
.featured-body h3{ font-size: .9rem; margin-bottom: .2rem; }
.featured-body p{ font-size: .82rem; color: var(--muted2); margin: 0; }

/* ─── SHOP TABS ─── */
.shop-tabs{
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  margin: 1.5rem 0;
}
.tab-btn{
  padding: .45rem .9rem;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: transparent;
  color: var(--muted);
  font-family: inherit;
  font-size: .9rem;
  cursor: pointer;
  transition: all 0.2s;
}
.tab-btn:hover{ border-color: var(--muted); color: var(--fg); }
.tab-btn.active{ background: var(--fg); color: #000; border-color: var(--fg); font-weight: 700; }

/* ─── PRODUCT GRID & CARDS ─── */
.product-grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(270px, 1fr));
  gap: 1.5rem;
  margin-top: 1rem;
}
.product-card{
  border: 1px solid var(--line);
  background: var(--panel);
  border-radius: 1rem;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color 0.3s, transform 0.3s, background 0.3s;
}
.product-card:hover{ border-color: rgba(255,255,255,.35); transform: translateY(-6px); background: var(--panel2); }
.product-thumb{
  width: 100%;
  height: 220px;
  background: linear-gradient(135deg, rgba(255,255,255,.1), rgba(255,255,255,.04));
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background-size: cover;
  background-position: center;
  overflow: hidden;
}
.product-thumb::after{
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 60%, rgba(0,0,0,.4));
  opacity: 0;
  transition: opacity 0.3s;
}
.product-card:hover .product-thumb::after{ opacity: 1; }
.product-badge{
  position: absolute;
  top: .75rem;
  left: .75rem;
  padding: .2rem .6rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.2);
  background: rgba(0,0,0,.65);
  color: var(--muted);
  font-size: .72rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  backdrop-filter: blur(6px);
  z-index: 1;
}
.product-thumb-label{
  color: var(--muted2);
  font-size: .85rem;
  text-align: center;
  padding: 1rem;
  z-index: 1;
}
.product-body{
  padding: 1rem;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.product-body h3{ font-size: 1rem; margin-bottom: .35rem; }
.product-body > p{ font-size: .88rem; color: var(--muted2); flex: 1; margin-bottom: .75rem; }
.product-footer{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
  flex-wrap: wrap;
  margin-top: auto;
  padding-top: .75rem;
  border-top: 1px solid var(--line);
}
.product-price{ font-size: 1rem; font-weight: 700; }
.btn-sm{
  padding: .38rem .75rem;
  font-size: .82rem;
  border-radius: .6rem;
}
.section-divider{
  margin: 2.5rem 0 1rem;
  padding-top: 2rem;
  border-top: 1px solid var(--line);
  display: flex;
  align-items: center;
  gap: 1rem;
}
.section-divider h2{ margin: 0; }

/* ─── ENQUIRY BASKET WIDGET ─── */
.basket-widget{
  position: fixed;
  bottom: 1.75rem;
  right: 1.75rem;
  z-index: 150;
}
.basket-toggle{
  position: relative;
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 50%;
  background: var(--fg);
  color: #000;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  box-shadow: 0 4px 24px rgba(0,0,0,.55);
  transition: transform 0.2s, filter 0.2s;
}
.basket-toggle:hover{ transform: scale(1.08); filter: brightness(.88); }
.basket-count{
  position: absolute;
  top: -.3rem;
  right: -.3rem;
  background: #e53535;
  color: #fff;
  font-size: .68rem;
  font-weight: 700;
  border-radius: 50%;
  width: 1.35rem;
  height: 1.35rem;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: scaleIn 0.2s ease-out;
}
.basket-count.hidden{ display: none; }
.basket-panel{
  position: absolute;
  bottom: 4.5rem;
  right: 0;
  width: 320px;
  max-height: 480px;
  background: #111;
  border: 1px solid var(--line);
  border-radius: 1.25rem;
  display: none;
  flex-direction: column;
  box-shadow: 0 12px 48px rgba(0,0,0,.75);
  overflow: hidden;
}
.basket-panel.open{ display: flex; animation: scaleIn 0.25s ease-out; transform-origin: bottom right; }
.basket-header{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--line);
}
.basket-header h3{ margin: 0; font-size: 1rem; }
.basket-close{
  background: none;
  border: none;
  color: var(--muted);
  cursor: pointer;
  font-size: 1.1rem;
  padding: .25rem;
  transition: color 0.2s;
}
.basket-close:hover{ color: var(--fg); }
.basket-items{
  flex: 1;
  overflow-y: auto;
  padding: .75rem 1.25rem;
}
.basket-empty{
  color: var(--muted2);
  font-size: .88rem;
  text-align: center;
  padding: 1.5rem 0;
  margin: 0;
}
.basket-item{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  padding: .65rem 0;
  border-bottom: 1px solid var(--line);
}
.basket-item:last-child{ border-bottom: none; }
.basket-item-name{ font-size: .88rem; }
.basket-item-price{ font-size: .78rem; color: var(--muted2); }
.basket-remove{
  background: none;
  border: none;
  color: var(--muted2);
  cursor: pointer;
  font-size: .85rem;
  flex-shrink: 0;
  padding: .25rem;
  transition: color 0.2s;
}
.basket-remove:hover{ color: var(--fg); }
.basket-footer{
  padding: 1rem 1.25rem;
  border-top: 1px solid var(--line);
}
.basket-footer .btn{ width: 100%; text-align: center; justify-content: center; }

/* ─── FLOATING ORBS (decorative bg elements) ─── */
.orb{
  position: absolute;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,255,255,.04) 0%, transparent 70%);
  pointer-events: none;
  animation: float 8s ease-in-out infinite;
}

/* ─── ARTWORK BADGE ─── */
.badge-artwork{ border-color: rgba(200,160,255,.3); color: rgba(200,160,255,.8); }
.badge-upcycled{ border-color: rgba(100,200,120,.3); color: rgba(100,200,120,.8); }
.badge-oddbin{ border-color: rgba(255,200,80,.3); color: rgba(255,200,80,.8); }
.badge-designed{ border-color: rgba(100,180,255,.3); color: rgba(100,180,255,.8); }

/* ─── AUTH MODAL ─── */
.auth-overlay{position:fixed;inset:0;background:rgba(0,0,0,.8);z-index:2000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s;}
.auth-overlay.open{opacity:1;pointer-events:all;}
.auth-modal{background:var(--card);border:1px solid var(--line);border-radius:1.25rem;padding:2rem;width:min(440px,92vw);position:relative;transform:translateY(24px);transition:transform .25s;max-height:90vh;overflow-y:auto;}
.auth-overlay.open .auth-modal{transform:none;}
.auth-close-btn{position:absolute;top:1rem;right:1.1rem;background:none;border:none;color:var(--muted);font-size:1.5rem;cursor:pointer;line-height:1;padding:.25rem;}
.auth-modal-logo{font-weight:900;letter-spacing:.06em;font-size:1.05rem;margin-bottom:1.25rem;color:var(--fg);}
.auth-modal-logo span{color:var(--muted);}
.auth-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;}
.auth-tab{flex:1;padding:.55rem;border:1.5px solid var(--line);background:none;color:var(--muted);border-radius:.6rem;cursor:pointer;font-size:.88rem;font-weight:700;font-family:inherit;transition:all .15s;letter-spacing:.02em;}
.auth-tab.active{background:var(--fg);color:var(--bg);border-color:var(--fg);}
.auth-form{display:flex;flex-direction:column;gap:.65rem;}
.auth-input{background:var(--panel);border:1.5px solid var(--line);border-radius:.65rem;padding:.75rem 1rem;color:var(--fg);font-size:.95rem;width:100%;font-family:inherit;transition:border-color .15s;box-sizing:border-box;}
.auth-input:focus{outline:none;border-color:var(--fg);}
.auth-input::placeholder{color:var(--muted2);}
.auth-msg{font-size:.82rem;padding:.6rem .85rem;border-radius:.5rem;display:none;line-height:1.45;}
.auth-msg.is-error{background:rgba(229,62,62,.12);border:1px solid rgba(229,62,62,.4);color:#fc8181;display:block;}
.auth-msg.is-ok{background:rgba(56,161,105,.12);border:1px solid rgba(56,161,105,.4);color:#68d391;display:block;}
.auth-small{font-size:.78rem;color:var(--muted2);text-align:center;margin-top:.25rem;line-height:1.5;}

/* ─── USER BAR ─── */
.user-bar{background:var(--panel);border-bottom:1px solid var(--line);padding:.55rem 0;display:none;}
.user-bar.show{display:block;}
.user-bar-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;}
.user-greeting{font-size:.88rem;color:var(--muted);}
.user-greeting strong{color:var(--fg);}
.btn-sign-out{background:none;border:1.5px solid var(--line);color:var(--muted);padding:.3rem .85rem;border-radius:.5rem;font-size:.8rem;font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s;letter-spacing:.02em;}
.btn-sign-out:hover{border-color:var(--fg);color:var(--fg);}

/* ─── PUBLIC QUIZ ─── */
.quiz-intro-text{max-width:600px;margin-bottom:2rem;}
.quiz-wrap{background:var(--card);border:1px solid var(--line);border-radius:1.25rem;overflow:hidden;max-width:720px;}
.quiz-prog-bar-track{height:3px;background:var(--line);}
.quiz-prog-bar-fill{height:100%;background:var(--fg);transition:width .45s ease;}
.quiz-prog-header{padding:1rem 1.5rem;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.quiz-prog-label{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted2);}
.quiz-prog-count{font-size:.8rem;color:var(--muted);white-space:nowrap;}
.quiz-body{padding:1.5rem 1.5rem 1.75rem;}
.quiz-q-num{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted2);margin-bottom:.4rem;}
.quiz-q-text{font-size:1.05rem;font-weight:600;line-height:1.5;margin-bottom:1.25rem;}
.quiz-options{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.1rem;}
.quiz-opt{display:flex;align-items:center;gap:.75rem;padding:.7rem 1rem;border:1.5px solid var(--line);border-radius:.75rem;cursor:pointer;transition:border-color .15s,background .15s;user-select:none;}
.quiz-opt:hover:not(.qlocked){border-color:var(--fg);}
.quiz-opt.qsel{border-color:var(--fg);background:var(--panel2);}
.quiz-opt.qcorrect{border-color:#38a169!important;background:rgba(56,161,105,.14)!important;}
.quiz-opt.qwrong{border-color:#e53e3e!important;background:rgba(229,62,62,.1)!important;}
.quiz-opt.qlocked{cursor:default;}
.quiz-opt-letter{width:1.9rem;height:1.9rem;min-width:1.9rem;border-radius:50%;border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;transition:all .15s;}
.quiz-opt.qsel .quiz-opt-letter{background:var(--fg);color:var(--bg);border-color:var(--fg);}
.quiz-opt.qcorrect .quiz-opt-letter{background:#38a169;color:#fff;border-color:#38a169;}
.quiz-opt.qwrong .quiz-opt-letter{background:#e53e3e;color:#fff;border-color:#e53e3e;}
.quiz-elab-label{font-size:.76rem;color:var(--muted2);margin-bottom:.35rem;display:block;}
.quiz-elab{width:100%;background:var(--panel);border:1.5px solid var(--line);border-radius:.75rem;padding:.8rem 1rem;color:var(--fg);font-size:.88rem;resize:vertical;min-height:72px;font-family:inherit;box-sizing:border-box;transition:border-color .15s;}
.quiz-elab:focus{outline:none;border-color:var(--fg);}
.quiz-elab::placeholder{color:var(--muted2);}
.quiz-feedback{padding:.7rem 1rem;border-radius:.65rem;font-size:.86rem;line-height:1.5;margin-top:.9rem;display:none;}
.quiz-feedback.fb-ok{background:rgba(56,161,105,.13);border:1px solid rgba(56,161,105,.5);color:#68d391;display:block;}
.quiz-feedback.fb-no{background:rgba(229,62,62,.1);border:1px solid rgba(229,62,62,.4);color:#fc8181;display:block;}
.quiz-btn-row{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.1rem;}

/* ─── DISCOUNT REVEAL ─── */
.discount-reveal{padding:2rem 1.5rem;text-align:center;border-top:1px solid var(--line);}
.discount-reveal-emoji{font-size:2.2rem;line-height:1;margin-bottom:.5rem;}
.discount-reveal h3{font-size:1.25rem;margin-bottom:.4rem;}
.discount-reveal .sub{color:var(--muted);font-size:.9rem;margin-bottom:1.25rem;}
.discount-code-box{display:inline-block;background:var(--panel2);border:2.5px dashed var(--fg);border-radius:.85rem;padding:.85rem 2rem;font-size:1.5rem;font-weight:900;letter-spacing:.2em;font-family:'Courier New',monospace;margin:.25rem 0 .75rem;cursor:pointer;transition:opacity .15s;}
.discount-code-box:hover{opacity:.7;}
.copy-hint{font-size:.72rem;color:var(--muted2);margin-bottom:1rem;}

/* ─── COURSE DASHBOARD ─── */
.enrolled-banner{background:rgba(56,161,105,.1);border:1px solid rgba(56,161,105,.35);border-radius:.85rem;padding:.8rem 1.25rem;font-size:.88rem;color:#68d391;margin-bottom:1.75rem;display:flex;align-items:center;gap:.6rem;}
.week-tab-btn.wlocked{opacity:.28;cursor:not-allowed;pointer-events:none;}
.week-tab-btn.wdone{position:relative;}
.week-tab-btn.wdone::after{content:'✓';position:absolute;top:-5px;right:-5px;background:#38a169;color:#fff;font-size:.5rem;width:.95rem;height:.95rem;border-radius:50%;display:flex;align-items:center;justify-content:center;line-height:1;}

/* ─── WEEKLY QUIZ BLOCK ─── */
.wk-quiz{margin-top:2rem;border:1px solid var(--line);border-radius:1rem;overflow:hidden;}
.wk-quiz-head{padding:.85rem 1.25rem;background:var(--panel);border-bottom:1px solid var(--line);font-weight:700;font-size:.9rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem;}
.wk-quiz-body{padding:1.5rem 1.25rem;}
.wk-quiz-done{padding:1.25rem 1.5rem;text-align:center;background:rgba(56,161,105,.1);}
.wk-quiz-done p{color:#68d391;font-weight:700;margin-bottom:.75rem;}
.wk-next-row{display:flex;justify-content:flex-end;margin-top:1.5rem;}
.enrol-prompt{background:var(--panel);border:1px solid var(--line);border-radius:1rem;padding:1.5rem;text-align:center;margin-top:2rem;}
.enrol-prompt p{color:var(--muted);margin-bottom:1rem;}

/* ─── DISCOUNT FIELD ON ENROLMENT ─── */
.discount-field-wrap{position:relative;}
.discount-field-badge{position:absolute;right:1rem;top:50%;transform:translateY(-50%);font-size:.75rem;font-weight:700;color:#68d391;display:none;}
.discount-field-badge.show{display:block;}
.link-btn{background:none;border:none;color:var(--fg);cursor:pointer;font-family:inherit;font-size:inherit;padding:0;text-decoration:underline;text-underline-offset:2px;}
.link-btn:hover{opacity:.7;}

/* ─── CINEMATIC BANNER ─── */
.cinematic-banner{
  position:relative;
  width:100%;
  height:90vh;
  min-height:480px;
  overflow:hidden;
  background:#000;
  border-bottom:1px solid var(--line);
}
.sr-only{
  position:absolute;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}
.cb-slide{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  opacity:0;
  transition:opacity 1.1s ease;
  will-change:opacity,transform;
}
.cb-slide.is-active{
  opacity:1;
  animation:cb-kenburns 8s ease-out forwards;
}
@keyframes cb-kenburns{
  from{transform:scale(1.07);}
  to{transform:scale(1);}
}
.cb-overlay{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding-bottom:4.5rem;
  background:linear-gradient(to top,rgba(0,0,0,.78) 0%,rgba(0,0,0,.22) 52%,rgba(0,0,0,.08) 100%);
  pointer-events:none;
}
.cb-label{
  font-size:.68rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(255,255,255,.6);
  margin-bottom:.5rem;
}
.cb-title{
  font-size:clamp(3rem,8vw,6rem);
  font-weight:700;
  letter-spacing:-0.03em;
  line-height:1;
  margin:0 0 .65rem;
  color:#fff;
}
.cb-sub{
  font-size:clamp(.9rem,2vw,1.15rem);
  color:rgba(255,255,255,.78);
  margin:0;
  max-width:50ch;
}
.cb-nav{
  position:absolute;
  bottom:1.75rem;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  gap:.5rem;
  z-index:10;
  align-items:center;
}
.cb-dot{
  width:6px;height:6px;
  border-radius:3px;
  background:rgba(255,255,255,.38);
  border:none;
  cursor:pointer;
  padding:0;
  transition:background .3s ease, width .5s cubic-bezier(0.34,1.56,0.64,1);
}
.cb-dot.is-active{background:#fff;width:26px;}
.cb-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.18);
  color:#fff;
  width:3rem;height:3rem;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  z-index:10;
  backdrop-filter:blur(8px);
  transition:background .2s, transform .35s cubic-bezier(0.34,1.56,0.64,1);
  font-size:1.4rem;
  line-height:1;
  padding:0;
}
.cb-arrow:hover{background:rgba(255,255,255,.22);transform:translateY(-50%) scale(1.1);}
.cb-arrow.prev{left:1.5rem;}
.cb-arrow.next{right:1.5rem;}
.cb-progress{
  position:absolute;
  bottom:0;left:0;
  width:100%;height:2px;
  background:rgba(255,255,255,.12);
  z-index:10;
}
.cb-progress-fill{height:100%;width:0%;background:rgba(255,255,255,.7);}
@media(max-width:600px){
  .cinematic-banner{height:78vh;}
  .cb-title{font-size:clamp(2.2rem,9vw,3.5rem);}
  .cb-arrow{display:none;}
  .cb-sub{font-size:.88rem;}
}

/* ─── EXPANDABLE / READ-MORE TEXT ─── */
.expandable-p{overflow:hidden;}
.expandable-p.is-collapsed{
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.read-more-btn{
  background:none;
  border:none;
  color:rgba(255,255,255,.8);
  cursor:pointer;
  font-size:.83rem;
  font-family:inherit;
  padding:.3rem 0 0;
  text-decoration:underline;
  text-underline-offset:3px;
  display:inline-block;
  margin-top:.1rem;
  transition:color .2s;
  letter-spacing:.02em;
}
.read-more-btn:hover{color:#fff;}

/* ─── PRODUCT DESIGN PAGE ─── */
.product-tabs-nav{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2rem;}
.product-tab-btn{padding:.55rem 1.25rem;border:1.5px solid var(--line);background:none;color:var(--muted);border-radius:2rem;cursor:pointer;font-size:.85rem;font-weight:700;font-family:inherit;letter-spacing:.04em;transition:all .15s;}
.product-tab-btn:hover{border-color:var(--fg);color:var(--fg);}
.product-tab-btn.active{background:var(--fg);color:var(--bg);border-color:var(--fg);}
.product-panel{display:none;}
.product-panel.active{display:block;}

/* Flask gallery */
.flask-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2.5rem;}
@media(max-width:700px){.flask-gallery{grid-template-columns:1fr 1fr;}}
@media(max-width:480px){.flask-gallery{grid-template-columns:1fr;}}
.flask-img-wrap{border-radius:1rem;overflow:hidden;aspect-ratio:3/4;position:relative;cursor:pointer;background:var(--panel);}
.flask-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease;}
.flask-img-wrap:hover img{transform:scale(1.04);}
.flask-img-label{position:absolute;bottom:0;left:0;right:0;padding:.6rem .85rem;background:linear-gradient(transparent,rgba(0,0,0,.7));font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.85);}

/* Lightbox */
.lightbox-overlay{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:3000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s;}
.lightbox-overlay.open{opacity:1;pointer-events:all;}
.lightbox-img{max-width:90vw;max-height:88vh;border-radius:.75rem;object-fit:contain;}
.lightbox-close{position:absolute;top:1.25rem;right:1.5rem;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;line-height:1;opacity:.7;}
.lightbox-close:hover{opacity:1;}

/* Product info strip */
.product-info-strip{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem;margin-bottom:2.5rem;}
@media(max-width:600px){.product-info-strip{grid-template-columns:1fr;}}
.product-info-cell{background:var(--panel);border:1px solid var(--line);border-radius:.85rem;padding:1rem 1.25rem;}
.product-info-cell .cell-label{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted2);margin-bottom:.35rem;}
.product-info-cell .cell-val{font-size:.95rem;font-weight:600;color:var(--fg);}

/* Poll */
.poll-section{border-top:1px solid var(--line);padding-top:2rem;}
.poll-title{font-size:1.2rem;font-weight:700;margin-bottom:.4rem;}
.poll-sub{color:var(--muted);font-size:.9rem;margin-bottom:1.75rem;}
.poll-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
@media(max-width:600px){.poll-grid{grid-template-columns:1fr;}}
.poll-card{background:var(--card);border:1.5px solid var(--line);border-radius:1rem;padding:1.25rem;}
.poll-card.answered-yes{border-color:#38a169;background:rgba(56,161,105,.08);}
.poll-card.answered-no{border-color:rgba(229,62,62,.5);background:rgba(229,62,62,.06);}
.poll-q{font-size:.9rem;font-weight:600;line-height:1.45;margin-bottom:1rem;}
.poll-q .poll-tag{display:inline-block;font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted2);margin-bottom:.35rem;}
.poll-btns{display:flex;gap:.6rem;}
.poll-btn{flex:1;padding:.6rem;border:1.5px solid var(--line);background:none;color:var(--fg);border-radius:.65rem;font-size:.88rem;font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:.4rem;}
.poll-btn:hover{border-color:var(--fg);}
.poll-btn.yes-btn.picked{background:#38a169;border-color:#38a169;color:#fff;}
.poll-btn.no-btn.picked{background:rgba(229,62,62,.85);border-color:rgba(229,62,62,.85);color:#fff;}
.poll-submit-row{margin-top:1.75rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap;}
.poll-thanks{background:rgba(56,161,105,.12);border:1px solid rgba(56,161,105,.4);border-radius:.85rem;padding:1rem 1.25rem;color:#68d391;font-size:.9rem;display:none;margin-top:1.5rem;}
.poll-thanks.show{display:block;}
.poll-results-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-top:1rem;}
@media(max-width:600px){.poll-results-grid{grid-template-columns:1fr;}}
.poll-result-item{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:var(--muted);}
.poll-result-item .r-label{font-weight:600;color:var(--fg);}
.poll-result-item .r-val{font-size:.8rem;padding:.2rem .65rem;border-radius:2rem;font-weight:700;}
.poll-result-item .r-yes{background:rgba(56,161,105,.2);color:#68d391;}
.poll-result-item .r-no{background:rgba(229,62,62,.15);color:#fc8181;}

/* Material swatches */
.material-swatches{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:.5rem;}
.swatch{width:1.6rem;height:1.6rem;border-radius:50%;border:2px solid var(--line);display:inline-block;flex-shrink:0;}
.swatch.steel{background:linear-gradient(135deg,#c0c0c0,#e8e8e8,#a8a8a8);}
.swatch.copper{background:linear-gradient(135deg,#b87333,#da8a67,#9e5e2a);}
.swatch.gold{background:linear-gradient(135deg,#c9a84c,#f5d76e,#9a7c2a);}

/* ── GALLERY ARTWORK SUBMISSION ── */
.file-upload-wrap{position:relative;border:2px dashed var(--line);border-radius:.85rem;padding:2rem 1rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;margin-top:.5rem;overflow:hidden;}
.file-upload-wrap:hover,.file-upload-wrap.drag-over{border-color:var(--fg);background:rgba(255,255,255,.03);}
.file-upload-wrap input[type="file"]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;}
.file-upload-ui{display:flex;flex-direction:column;align-items:center;gap:.5rem;pointer-events:none;}
.file-upload-icon{font-size:2rem;}
.file-upload-text{font-size:.9rem;color:var(--muted);}
.file-preview{display:none;max-width:100%;max-height:260px;border-radius:.65rem;margin-top:1rem;object-fit:contain;}
.file-preview.show{display:block;}

/* ── CLIENT WORK BLOCKS ── */
.work-client-block{border:1px solid var(--line);border-radius:1rem;padding:1.5rem;background:var(--card);}
.work-client-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap;margin-bottom:1.25rem;}
.work-client-meta{display:flex;flex-wrap:wrap;gap:.4rem;align-items:flex-start;}
.work-photo-grid{display:grid;gap:.75rem;margin-top:.25rem;}
.work-photo-slot{border-radius:.65rem;overflow:hidden;aspect-ratio:4/3;background:var(--panel);border:1.5px dashed var(--line);position:relative;}
.work-photo-slot img{width:100%;height:100%;object-fit:cover;display:block;}
.work-photo-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;}
.wpp-icon{font-size:1.75rem;opacity:.45;}
.wpp-text{font-size:.75rem;color:var(--muted2);font-weight:600;letter-spacing:.04em;text-transform:uppercase;}
@media(max-width:600px){.work-photo-grid{grid-template-columns:repeat(2,1fr)!important;}.work-client-header{flex-direction:column;}}
