/* ===========================================================
   MCB STUDIO RENTALS — SHARED DESIGN SYSTEM
   Tokens grounded in the brand's real rate-card material:
   orange/charcoal ribbon price tags, Bebas Neue + Montserrat,
   and the infinity-cove curve from the Studio 01 floor as the
   recurring signature divider motif used across every page.
   =========================================================== */

:root{
  --ink:#15130f;
  --paper:#faf7f2;
  --paper-dim:#f1ece2;
  --orange:#e8491a;
  --orange-dark:#c93c13;
  --charcoal:#232220;
  --line:#e3dccd;
  --muted:#6b6457;
  --green:#1f8a4c;
  --max:1180px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
section[id]{scroll-margin-top:90px;}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:'Montserrat',sans-serif;
  -webkit-font-smoothing:antialiased;
}
.display{font-family:'Bebas Neue',sans-serif;letter-spacing:.5px;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
.container{max-width:var(--max);margin:0 auto;padding:0 24px;}
@media (prefers-reduced-motion: reduce){ *{animation:none !important;transition:none !important;} }
:focus-visible{outline:3px solid var(--orange);outline-offset:2px;}

/* ---------- Curve divider (signature motif) ---------- */
.curve-divider{width:100%;height:64px;display:block;}
.curve-divider path{fill:var(--paper);}
.curve-divider.flip{transform:rotate(180deg);}
.curve-divider.on-ink path{fill:var(--ink);}
.curve-divider.on-charcoal path{fill:var(--charcoal);}

/* ---------- Nav ---------- */
.nav{position:sticky;top:0;z-index:100;background:var(--ink);color:#fff;}
.nav-inner{max-width:var(--max);margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;gap:18px;}
.nav-brand{font-family:'Bebas Neue',sans-serif;font-size:24px;color:var(--orange);white-space:nowrap;display:inline-flex;align-items:center;gap:10px;}
.nav-logo{height:32px;width:auto;display:block;}
.nav-brand span{color:#fff;margin-left:6px;}
.nav-links{display:flex;align-items:center;gap:26px;font-size:13.5px;font-weight:600;letter-spacing:.3px;}
.nav-links a{opacity:.82;transition:opacity .15s;}
.nav-links a:hover, .nav-links a.active{opacity:1;color:var(--orange);}
.nav-cta{background:var(--orange);color:#fff !important;padding:10px 18px;border-radius:7px;font-weight:700;font-size:13px;white-space:nowrap;}
.nav-cta:hover{background:var(--orange-dark);}
.nav-toggle{display:none;background:none;border:none;color:#fff;font-size:26px;cursor:pointer;}
@media (max-width:860px){
  .nav-links{position:absolute;top:100%;left:0;right:0;background:var(--ink);flex-direction:column;align-items:flex-start;padding:6px 24px 20px;gap:14px;display:none;}
  .nav-links.open{display:flex;}
  .nav-toggle{display:block;}
}

/* ---------- Hero ---------- */
.hero{position:relative;background:var(--ink);color:#fff;padding:90px 0 70px;overflow:hidden;}
.hero-eyebrow{font-size:12.5px;letter-spacing:3px;text-transform:uppercase;color:var(--orange);font-weight:700;margin-bottom:14px;}
.hero h1{font-family:'Bebas Neue',sans-serif;font-size:clamp(40px,6vw,72px);line-height:1.02;margin:0 0 18px;max-width:780px;}
.hero p.lead{font-size:16px;color:#d8d4c9;max-width:560px;line-height:1.7;margin:0 0 30px;}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border-radius:8px;font-weight:700;font-size:14px;cursor:pointer;border:none;font-family:'Montserrat';transition:.15s;}
.btn-primary{background:var(--orange);color:#fff;}
.btn-primary:hover{background:var(--orange-dark);}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.35);}
.btn-ghost:hover{border-color:#fff;}
.btn-dark{background:var(--ink);color:#fff;}
.btn-dark:hover{background:#000;}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid var(--line);}
.btn-outline:hover{border-color:var(--orange);color:var(--orange);}

/* ---------- Section basics ---------- */
.section{padding:70px 0;}
.section-tight{padding:40px 0;}
.eyebrow{font-size:12.5px;letter-spacing:3px;text-transform:uppercase;color:var(--orange);font-weight:700;margin-bottom:10px;}
.section-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(30px,4vw,44px);margin:0 0 14px;}
.section-lead{color:var(--muted);max-width:560px;font-size:15px;line-height:1.7;margin-bottom:36px;}
.on-ink{background:var(--ink);color:#fff;}
.on-ink .section-lead{color:#c9c4b6;}
.on-charcoal{background:var(--charcoal);color:#fff;}

/* ---------- Cards / grids ---------- */
.grid{display:grid;gap:22px;}
.grid-2{grid-template-columns:repeat(2,1fr);}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-4{grid-template-columns:repeat(4,1fr);}
@media (max-width:900px){ .grid-3,.grid-4{grid-template-columns:repeat(2,1fr);} }
@media (max-width:600px){ .grid-2,.grid-3,.grid-4{grid-template-columns:1fr;} }

.card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px;}
.card-dark{background:var(--ink);color:#fff;border-radius:14px;padding:26px;}
.num-tag{font-family:'Bebas Neue';font-size:13px;background:var(--orange);color:#fff;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;margin-bottom:14px;flex-shrink:0;}

.card-link{display:flex;flex-direction:column;height:100%;text-decoration:none;color:inherit;transition:transform .18s,box-shadow .18s,border-color .18s;}
.card-link:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(21,19,15,.09);border-color:var(--orange);}
.card-link-top{display:flex;align-items:center;gap:12px;margin-bottom:10px;}
.card-link-top .num-tag{margin-bottom:0;}
.card-link-top h3{margin:0;font-size:16px;line-height:1.3;}
.card-link p{font-size:13px;color:var(--muted);margin:0 0 16px;line-height:1.55;flex:1;}
.card-link-arrow{font-size:12px;font-weight:700;color:var(--orange-dark);letter-spacing:.2px;display:inline-flex;align-items:center;gap:4px;transition:gap .15s;}
.card-link:hover .card-link-arrow{gap:8px;}

.space-card{position:relative;border-radius:16px;overflow:hidden;background:var(--charcoal);background-size:cover;background-position:center;color:#fff;min-height:300px;display:flex;flex-direction:column;justify-content:flex-end;padding:26px;}
.space-card.bg-1{background-image:linear-gradient(180deg, rgba(20,18,16,.2) 0%, rgba(13,11,9,.93) 85%), url('images/studio01-hero.jpg');}
.space-card.bg-2{background-image:linear-gradient(180deg, rgba(20,18,16,.2) 0%, rgba(13,11,9,.93) 85%), url('images/studio02-hero.jpg');}
.space-card.bg-3{background-image:linear-gradient(180deg, rgba(20,18,16,.2) 0%, rgba(13,11,9,.93) 85%), url('images/studio-04-podcast-desk.jpg');}
.space-card .tag{position:absolute;top:18px;left:18px;font-family:'Bebas Neue';background:rgba(0,0,0,.5);padding:4px 12px;border-radius:20px;font-size:13px;letter-spacing:1px;}
.space-card h3{font-family:'Bebas Neue';font-size:26px;margin:0 0 6px;}
.space-card p{font-size:13px;color:#d8d4c9;margin:0 0 14px;line-height:1.6;}

/* ---------- Placeholder visual tile (for gallery / no-photo states) ---------- */
.ph-tile{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:4/3;min-height:180px;background:
    repeating-linear-gradient(135deg, rgba(232,73,26,.08) 0 18px, rgba(35,34,32,.05) 18px 36px),
    var(--paper-dim);
  display:flex;align-items:center;justify-content:center;border:1.5px dashed var(--line);
}
.ph-tile .ph-label{font-family:'Bebas Neue';color:var(--muted);font-size:15px;text-align:center;padding:0 16px;}
.ph-tile .ph-sub{display:block;font-family:'Montserrat';font-size:11px;color:#9a9384;margin-top:4px;}

/* ---------- Rate-card style pricing rows (echoes the real PDF rate card) ---------- */
.rate-row{display:flex;justify-content:space-between;align-items:center;border-radius:8px;overflow:hidden;margin-bottom:8px;}
.rate-row .label{background:var(--orange);color:#fff;padding:12px 16px;font-weight:700;font-size:13.5px;flex:1;}
.rate-row .amount{background:var(--charcoal);color:#fff;padding:12px 18px;font-weight:800;font-size:14px;white-space:nowrap;}
.price-pending{background:var(--paper-dim);color:var(--muted) !important;font-style:italic;font-weight:600 !important;}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:#cfcabd;padding:56px 0 28px;font-size:13.5px;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;margin-bottom:40px;}
@media (max-width:700px){ .footer-grid{grid-template-columns:1fr;} }
.footer-brand{font-family:'Bebas Neue';font-size:22px;color:var(--orange);margin-bottom:10px;display:flex;align-items:center;gap:10px;}
.footer-logo{height:30px;width:auto;display:block;}
.footer h4{color:#fff;font-size:12.5px;letter-spacing:1.5px;text-transform:uppercase;margin:0 0 14px;}
.footer a{opacity:.85;}
.footer a:hover{opacity:1;color:var(--orange);}
.footer-links{display:flex;flex-direction:column;gap:10px;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;font-size:12px;opacity:.6;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;}

/* ---------- Forms ---------- */
.field{margin-bottom:16px;}
.field label{display:block;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:6px;}
.field input, .field select, .field textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:8px;font-family:'Montserrat';font-size:14.5px;background:#fff;color:var(--ink);}
.field input:focus, .field select:focus, .field textarea:focus{outline:none;border-color:var(--orange);}
.row{display:flex;gap:14px;flex-wrap:wrap;}
.row .field{flex:1;min-width:160px;}

.msg{padding:12px 14px;border-radius:8px;font-size:13.5px;margin-top:12px;}
.msg.error{background:#fde8e0;color:#c23b3b;}
.msg.success{background:#e6f4ea;color:var(--green);}
.msg.info{background:var(--paper-dim);color:var(--muted);}

/* ---------- CTA banner ---------- */
.cta-banner{background:var(--orange);color:#fff;border-radius:18px;padding:48px;text-align:center;}
.cta-banner h2{font-family:'Bebas Neue';font-size:clamp(28px,4vw,40px);margin:0 0 12px;}
.cta-banner p{max-width:480px;margin:0 auto 24px;color:#fff;opacity:.92;}

/* ---------- Scroll reveal ----------
   IMPORTANT: .reveal alone stays fully visible (default state).
   JS adds .reveal-armed on load, THEN the hidden/animate-in styles apply.
   This means if JS is slow or blocked, content still shows normally. */
.reveal.reveal-armed{opacity:0;transform:translateY(26px);transition:opacity .7s ease, transform .7s ease;}
.reveal.reveal-armed.revealed{opacity:1;transform:translateY(0);}
.reveal.delay-1.revealed{transition-delay:.1s;}
.reveal.delay-2.revealed{transition-delay:.2s;}
.reveal.delay-3.revealed{transition-delay:.3s;}
@media (prefers-reduced-motion: reduce){ .reveal.reveal-armed{opacity:1;transform:none;} }

/* ---------- Hover lift ---------- */
.card, .space-card{transition:transform .25s ease, box-shadow .25s ease;}
.card:hover{transform:translateY(-5px);box-shadow:0 14px 30px rgba(21,19,15,.09);}
.space-card:hover{transform:translateY(-5px);}
.ph-tile{transition:transform .2s ease;cursor:pointer;}
.ph-tile:hover{transform:translateY(-3px);}

/* ---------- Hero slider ---------- */
.hero-slider{position:relative;background:var(--ink);color:#fff;overflow:hidden;min-height:560px;display:flex;align-items:center;}
.hero-slider .slide{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity .9s ease;display:flex;align-items:center;padding:90px 0 90px;background-size:cover;background-position:center;}
.hero-slider .slide.active{opacity:1;visibility:visible;z-index:1;}
.hero-slider .slide.slide-1{background-image:linear-gradient(100deg, rgba(13,11,9,.92) 0%, rgba(13,11,9,.72) 35%, rgba(13,11,9,.4) 75%), url('images/studio01-hero.jpg');}
.hero-slider .slide.slide-2{background-image:linear-gradient(100deg, rgba(13,11,9,.92) 0%, rgba(13,11,9,.72) 35%, rgba(13,11,9,.4) 75%), url('images/studio02-hero.jpg');}
.hero-slider .slide.slide-3{background-image:linear-gradient(100deg, rgba(13,11,9,.92) 0%, rgba(13,11,9,.72) 35%, rgba(13,11,9,.4) 75%), url('images/studio-04-podcast-desk.jpg');}
.slide-bg-num{position:absolute;right:-30px;top:-40px;font-family:'Bebas Neue';font-size:380px;line-height:1;color:rgba(255,255,255,.045);z-index:0;pointer-events:none;user-select:none;}
.slide-content{position:relative;z-index:1;max-width:680px;}
.slider-controls{position:absolute;bottom:26px;left:0;right:0;display:flex;justify-content:center;align-items:center;gap:18px;z-index:2;}
.slider-dots{display:flex;gap:8px;align-items:center;}
.slider-dots button{width:9px;height:9px;border-radius:50%;border:none;background:rgba(255,255,255,.3);cursor:pointer;padding:0;transition:.2s;}
.slider-dots button.active{background:var(--orange);width:22px;border-radius:5px;}
.slider-arrow{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.25);color:#fff;width:38px;height:38px;border-radius:50%;cursor:pointer;font-size:17px;line-height:1;}
.slider-arrow:hover{background:rgba(255,255,255,.18);}

/* ---------- Testimonial slider ---------- */
.testi-slider{position:relative;max-width:680px;margin:0 auto;min-height:170px;}
.testi-slider .slide{display:none;text-align:center;}
.testi-slider .slide.active{display:block;}
.testi-quote{font-size:19px;line-height:1.6;font-style:italic;margin:0 0 18px;}
.testi-name{font-weight:800;font-size:14px;}
.testi-role{font-size:12.5px;color:var(--muted);}
.testi-slider .slider-controls{position:relative;bottom:auto;margin-top:24px;}
.testi-slider .slider-dots button{background:var(--line);}
.testi-slider .slider-dots button.active{background:var(--orange);}
.testi-slider .slider-arrow{background:var(--paper-dim);border-color:var(--line);color:var(--ink);}

/* ---------- Lightbox ---------- */
.lightbox-overlay{position:fixed;inset:0;background:rgba(15,13,10,.86);display:none;align-items:center;justify-content:center;z-index:1000;padding:30px;}
.lightbox-overlay.open{display:flex;}
.lightbox-box{max-width:600px;width:100%;}
.lightbox-close{position:absolute;top:22px;right:26px;color:#fff;font-size:30px;cursor:pointer;background:none;border:none;line-height:1;}

/* ---------- Vendor auth pages ---------- */
.auth-wrap{max-width:430px;margin:60px auto;padding:0 20px;}
.auth-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:34px;}
.auth-switch{text-align:center;font-size:13px;color:var(--muted);margin-top:18px;}
.auth-switch a{color:var(--orange);font-weight:700;}

/* ---------- Vendor dashboard ---------- */
.dash-topbar{background:var(--ink);color:#fff;padding:16px 24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;}
.dash-topbar .brand{font-family:'Bebas Neue';font-size:22px;color:var(--orange);}
.dash-topbar .brand span{color:#fff;margin-left:6px;}

/* ---------- Admin dashboard shell (v2 — upgraded) ---------- */
.dash-shell{display:flex;min-height:100vh;}
.dash-sidebar{width:246px;background:linear-gradient(180deg,#1c1916,#0d0b09);color:#fff;flex-shrink:0;padding:22px 0 16px;display:flex;flex-direction:column;}
.dash-sidebar .brand-row{display:flex;align-items:center;gap:11px;padding:0 22px 20px;margin-bottom:12px;border-bottom:1px solid rgba(255,255,255,.08);}
.dash-logo-mark{width:36px;height:36px;border-radius:11px;background:linear-gradient(135deg,var(--orange),#ff8a5c);display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue';font-size:17px;flex-shrink:0;box-shadow:0 6px 14px -4px rgba(232,73,26,.5);}
.dash-sidebar .brand-text{font-family:'Bebas Neue';font-size:17px;line-height:1.15;letter-spacing:.3px;}
.dash-sidebar .brand-text .sub{display:block;font-family:'Montserrat';font-size:9.5px;letter-spacing:1.4px;color:#9a9384;text-transform:uppercase;margin-top:3px;font-weight:600;}
.dash-nav-group{padding:0 12px;}
.dash-nav-item{display:flex;align-items:center;gap:12px;padding:11px 14px;margin-bottom:3px;border-radius:10px;font-size:13.5px;font-weight:600;color:#a8a196;cursor:pointer;transition:background .15s, color .15s;}
.dash-nav-item svg{width:17px;height:17px;flex-shrink:0;opacity:.75;transition:opacity .15s;}
.dash-nav-item:hover{background:rgba(255,255,255,.05);color:#f1ede4;}
.dash-nav-item.active{background:rgba(232,73,26,.16);color:#fff;}
.dash-nav-item.active svg{opacity:1;color:var(--orange);}
.dash-sidebar-footer{margin-top:auto;padding:14px 12px 0;}

.dash-main{flex:1;min-width:0;background:
  radial-gradient(900px 460px at 105% -8%, rgba(232,73,26,.07), transparent 60%),
  #f5f2ec;}
.dash-header{background:rgba(250,248,245,.82);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line);padding:16px 30px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;position:sticky;top:0;z-index:20;}
.dash-header h1{font-family:'Bebas Neue';font-size:23px;margin:0;letter-spacing:.3px;}
.dash-header-right{display:flex;align-items:center;gap:18px;}
.live-pulse{display:flex;align-items:center;gap:8px;font-size:11.5px;color:var(--muted);font-weight:600;}
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--green);position:relative;flex-shrink:0;}
.live-dot::after{content:'';position:absolute;inset:0;border-radius:50%;background:var(--green);animation:pulseRing 1.8s infinite;}
@keyframes pulseRing{0%{transform:scale(1);opacity:.65;}100%{transform:scale(3);opacity:0;}}
.dash-bell{position:relative;width:36px;height:36px;border-radius:10px;border:1px solid var(--line);background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.15s;}
.dash-bell:hover{border-color:var(--orange);}
.dash-bell svg{width:16px;height:16px;color:var(--ink);}
.dash-bell .badge{position:absolute;top:-6px;right:-6px;background:var(--orange);color:#fff;font-size:10px;font-weight:800;min-width:17px;height:17px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;}
.dash-avatar{width:36px;height:36px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;cursor:pointer;flex-shrink:0;}
.dash-mobile-toggle{display:none;background:var(--ink);color:#fff;border:none;font-size:20px;padding:8px 11px;border-radius:8px;cursor:pointer;}
@media (max-width:860px){
  .dash-sidebar{position:fixed;top:0;left:0;bottom:0;z-index:200;transform:translateX(-100%);transition:transform .2s ease;}
  .dash-sidebar.open{transform:translateX(0);}
  .dash-mobile-toggle{display:block;}
}

.dash-body{padding:28px 30px 60px;}

.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:30px;}
@media (max-width:900px){ .stat-grid{grid-template-columns:repeat(2,1fr);} }
.stat-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:0 1px 2px rgba(20,18,15,.03), 0 10px 22px -10px rgba(20,18,15,.08);display:flex;flex-direction:column;gap:14px;transition:transform .2s ease, box-shadow .2s ease;}
.stat-card:hover{transform:translateY(-3px);box-shadow:0 1px 2px rgba(20,18,15,.04), 0 18px 30px -10px rgba(20,18,15,.12);}
.stat-icon{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.stat-icon svg{width:18px;height:18px;}
.stat-icon.orange{background:#fdeae1;color:var(--orange-dark);}
.stat-icon.green{background:#e3f3ea;color:var(--green);}
.stat-icon.ink{background:#eae7e0;color:var(--ink);}
.stat-card .label{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);font-weight:700;}
.stat-card .value{font-family:'Bebas Neue';font-size:32px;font-variant-numeric:tabular-nums;letter-spacing:.3px;}
.stat-card .value.orange{color:var(--orange);}

.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;margin-bottom:18px;}
.toolbar select, .toolbar input{padding:10px 14px;border:1.5px solid var(--line);border-radius:10px;font-family:'Montserrat';font-size:13px;background:#fff;}
.toolbar select:focus, .toolbar input:focus{outline:none;border-color:var(--orange);}

.data-table-wrap{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:0 1px 2px rgba(20,18,15,.03);}
.data-table-scroll{overflow-x:auto;}
table.data-table{width:100%;border-collapse:collapse;font-size:13px;min-width:760px;}
table.data-table th{text-align:left;padding:13px 16px;background:#faf8f5;font-size:10.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);white-space:nowrap;border-bottom:1px solid var(--line);}
table.data-table td{padding:13px 16px;border-top:1px solid var(--line);vertical-align:top;}
table.data-table tbody tr{transition:background .12s;}
table.data-table tbody tr:hover td{background:#fbf9f6;}
.row-actions{display:flex;gap:6px;flex-wrap:wrap;}
.row-actions button{border:1.5px solid var(--line);background:#fff;padding:6px 11px;border-radius:8px;font-size:11.5px;font-weight:700;cursor:pointer;white-space:nowrap;transition:.15s;}
.row-actions button:hover{border-color:var(--orange);color:var(--orange-dark);background:#fdf3ee;}
.row-actions button.danger:hover{border-color:#c23b3b;color:#c23b3b;background:#fdeeee;}
.status-pill{display:inline-flex;align-items:center;gap:6px;font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.3px;padding:4px 10px 4px 8px;border-radius:20px;white-space:nowrap;}

/* Shared event/session form pattern — used on admin-dashboard.html, classes-admin.html, vendor-dashboard.html */
.hidden{display:none !important;}
.session-row{align-items:flex-end;background:var(--paper-dim);border-radius:10px;padding:14px 14px 0;margin-bottom:10px;}
.session-row .field{margin-bottom:14px;}
.removeSessionBtn{border:none;background:none;color:var(--muted);font-size:20px;line-height:1;cursor:pointer;padding:0 4px 14px;}
.removeSessionBtn:hover{color:#c23b3b;}
.session-pill{display:inline-block;background:var(--paper-dim);border-radius:20px;padding:3px 10px;font-size:12px;margin:0 6px 6px 0;}
.session-pill.full{color:#c23b3b;}
.status-pill::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0;}
.status-pill.pending{background:#fdf1d6;color:#b8860b;}
.status-pill.confirmed,.status-pill.active{background:#e3f3ea;color:var(--green);}
.status-pill.cancelled,.status-pill.paused{background:#fde8e0;color:#c23b3b;}

.tab-panel{display:none;}
.tab-panel.active{display:block;animation:dashFadeIn .35s ease;}
@keyframes dashFadeIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}

.dash-panel-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px;margin-bottom:20px;box-shadow:0 1px 2px rgba(20,18,15,.03);}
.dash-panel-card h3{margin:0 0 16px;font-size:16px;font-family:'Bebas Neue';letter-spacing:.3px;}

/* ===== Studio 04 landing page ===== */
.hero.hero-image{background-image:linear-gradient(100deg, rgba(13,11,9,.93) 0%, rgba(13,11,9,.7) 45%, rgba(13,11,9,.38) 100%), url('images/studio-04-podcast-desk.jpg');background-size:cover;background-position:center;}

.compare-wrap{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:0 1px 2px rgba(20,18,15,.03);}
.compare-scroll{overflow-x:auto;}
table.compare-table{width:100%;border-collapse:collapse;min-width:680px;}
table.compare-table th{text-align:left;padding:16px 18px;background:var(--charcoal);color:#fff;font-family:'Bebas Neue';font-size:13px;letter-spacing:.6px;text-transform:uppercase;white-space:nowrap;}
table.compare-table td{padding:16px 18px;border-top:1px solid var(--line);vertical-align:top;font-size:14px;}
table.compare-table td.amount{font-family:'Bebas Neue';font-size:16px;color:var(--orange-dark);white-space:nowrap;}
table.compare-table tr.popular td{background:#fdf3ee;}
table.compare-table tr.popular td:first-child{position:relative;font-weight:700;}
.popular-flag{display:inline-block;margin-left:8px;font-family:'Bebas Neue';background:var(--orange);color:#fff;padding:2px 9px;border-radius:20px;font-size:10px;letter-spacing:.6px;vertical-align:middle;}

.equip-list{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
@media (max-width:760px){.equip-list{grid-template-columns:repeat(2,1fr);}}
.equip-item{display:flex;align-items:flex-start;gap:10px;padding:14px 16px;background:#fff;border:1px solid var(--line);border-radius:12px;font-size:13.5px;}
.equip-item .chk{flex-shrink:0;width:20px;height:20px;border-radius:50%;background:var(--orange);color:#fff;font-size:12px;display:flex;align-items:center;justify-content:center;margin-top:1px;}

.faq-item{border-bottom:1px solid var(--line);}
.faq-item:first-child{border-top:1px solid var(--line);}
.faq-item summary{padding:18px 4px;font-family:'Bebas Neue';font-size:15.5px;letter-spacing:.2px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{content:'+';font-size:22px;color:var(--orange);transition:transform .2s;}
.faq-item[open] summary::after{transform:rotate(45deg);}
.faq-item p{margin:0 4px 18px;color:var(--muted);font-size:14px;line-height:1.7;max-width:680px;}

.feature-quote{max-width:640px;margin:0 auto;text-align:center;}
.feature-quote .testi-quote{font-size:clamp(18px,2.4vw,24px);}

