/* =====================================================
   Tokens (safe fallbacks if your global tokens aren't set)
   ===================================================== */
:root{
  --surface: #ffffff;
  --surface-2: #f6f6f6;
  --text: #111214;
  --muted: #6b7280;
  --border: rgba(0,0,0,.08);
  --border-strong: rgba(0,0,0,.14);
  --radius: 16px;
  --shadow-sm: 0 4px 12px rgba(0,0,0,.06);
  --shadow: 0 18px 44px rgba(0,0,0,.12);

  --accent-1: #6366f1; /* indigo */
  --accent-2: #10b981; /* emerald */
}

/* =====================================================
   Cloud Hero
   ===================================================== */
@media (max-width: 768px){
  #cloud-hero h1,
  #cloud-hero p{ margin-left:10px; margin-right:10px; }
}

.hero{
  position:relative;
  width:100%;
  height:auto;
  background:hsl(210 80% 80%);
  overflow:hidden;
  font-family: 'Google Sans', system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  display:grid;
  place-items:center;
  align-content:center;
}

.hero-content{
  position:relative;
  z-index:20;
  padding-inline:25px;
}

/* Clouds (fix: animate transform as well for Safari/older Chrome) */
.cloud{
  position:absolute;
  top:100%;
  left:calc(var(--x, .5) * 100%);
  translate:-50% 0; /* modern shorthand */
  transform: translate(-50%, 0) rotateY(calc(var(--flipped, 0) * 180deg));
  width:calc(var(--size, 40) * 1vmin);
  animation: float calc(var(--speed, 30) * 1s) calc(var(--delay, 0) * 1s) linear reverse infinite;
  z-index:0;
  filter: drop-shadow(0 8px 20px rgba(0,0,0,.08));
  will-change: transform;
}

@-webkit-keyframes float{
  to{
    translate: -50% calc(-100vh - 100%);
    transform: translate(-50%, calc(-100vh - 100%)) rotateY(calc(var(--flipped, 0) * 180deg));
  }
}
@keyframes float{
  to{
    translate: -50% calc(-100vh - 100%);
    transform: translate(-50%, calc(-100vh - 100%)) rotateY(calc(var(--flipped, 0) * 180deg));
  }
}

@media (prefers-reduced-motion: reduce){
  .cloud{ animation:none; }
}

/* =====================================================
   Device frame (used for Mindful Times video)
   ===================================================== */
.device{
  border:1px solid var(--border);
  background:var(--surface);
  border-radius:20px;
  box-shadow:var(--shadow);
  overflow:hidden;
  transform:translateZ(0);
  animation: deviceFloat 8s ease-in-out infinite;
}
@keyframes deviceFloat{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(-6px); }
}
.device-chrome{
  display:flex; align-items:center; gap:.35rem;
  height:34px; padding:0 .6rem;
  border-bottom:1px solid var(--border);
  background: linear-gradient(#fafafa, #f3f4f6);
}
.gc-dot{ width:.5rem; height:.5rem; border-radius:50%; }
.gc-dot.red{ background:#ff5f56; } .gc-dot.amber{ background:#ffbd2e; } .gc-dot.green{ background:#27c93f; }

.device-media{
  position:relative;
  aspect-ratio:16 / 9;
  background:#000;
}

/* Aspect-ratio fallback */
@supports not (aspect-ratio: 16 / 9){
  .device-media{ height:0; padding-top:56.25%; }
  .device-media > *{ position:absolute; inset:0; }
}

.device-media > video{
  width:100%; height:100%;
  object-fit:cover;
  display:block;
  pointer-events:none; /* feel like a demo */
}
.device-label{
  position:absolute; right:.75rem; bottom:.75rem;
  padding:.25rem .55rem; font-size:.75rem; font-weight:700; color:#fff;
  background:rgba(0,0,0,.45); backdrop-filter: blur(4px);
  border-radius:999px; letter-spacing:.02em;
}

@media (prefers-reduced-motion: reduce){
  .device{ animation:none; }
}

/* =====================================================
   Plain media container (used for Google Calendar GIF)
   ===================================================== */
.gc-plain{
  border:1px solid var(--border);
  background:var(--surface);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}
.gc-plain .gc-media{ position:relative; aspect-ratio:16 / 10; background:#fff; }
@supports not (aspect-ratio: 16 / 10){
  .gc-plain .gc-media{ height:0; padding-top:62.5%; }
  .gc-plain .gc-media > img{ position:absolute; inset:0; }
}
.gc-plain .gc-media > img{
  width:100%; height:100%;
  display:block; background:#fff;
}

/* =====================================================
   Google Calendar section background + list polish
   ===================================================== */
#google-calendar.gc-stylish{
  background: var(--surface-2) !important;
  border-top:1px solid var(--border);
  position:relative; overflow:hidden; isolation:isolate;
}
#google-calendar.gc-stylish::before{
  content:"";
  position:absolute; inset:-20% -10% auto -10%;
  height:60%; z-index:-1;
  background:
    radial-gradient(60% 70% at 8% 15%, rgba(99,102,241,.10), transparent 60%),
    radial-gradient(70% 60% at 90% 0%, rgba(16,185,129,.10), transparent 60%);
  filter: blur(22px); opacity:.6;
}
#google-calendar ul{ margin:.75rem 0 0; padding-left:1.1rem; }
#google-calendar ul li{ margin:.3rem 0; color:var(--muted); }
#google-calendar ul li::marker{ color:var(--muted); }

/* =====================================================
   (Optional) Interactive iframe preview styles (keep if used elsewhere)
   ===================================================== */
.mt-iframe-card{
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--surface);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}
.mt-iframe-frame{ position:relative; aspect-ratio:16 / 9; background:#000; overflow:hidden; }
@supports not (aspect-ratio: 16 / 9){
  .mt-iframe-frame{ height:0; padding-top:56.25%; }
  .mt-iframe-frame > iframe{ position:absolute; inset:0; }
}
.mt-iframe-frame > iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.mt-iframe-shield{ position:absolute; inset:0; background:transparent; cursor:default; }
.mt-iframe-label{
  position:absolute; right:.75rem; bottom:.65rem;
  padding:.25rem .6rem; font-size:.75rem; font-weight:700; color:#fff;
  background:rgba(0,0,0,.45); backdrop-filter: blur(4px);
  border-radius:999px; letter-spacing:.02em;
}
@media (prefers-reduced-motion: reduce){ .mt-iframe-label{ display:none; } }



    /* ===== Feature Overview (compact slider with shadow bleed) ===== */
.feature-band{
  position: relative;
  background: var(--surface-2, #f6f6f6);
  border-top: 1px solid var(--border, rgba(0,0,0,.08));
  isolation: isolate;
  overflow: visible; /* allow children to render outside */
}

/* header */
.feature-band .section-head{ margin-bottom: .5rem; }
.feature-band .eyebrow{
  display:inline-flex; align-items:center; gap:.5rem;
  font-size:.75rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase;
  color:var(--muted,#6b7280);
  padding:.25rem .6rem; border:1px solid var(--border,rgba(0,0,0,.08));
  border-radius:999px; background:var(--surface,#fff);
}
.feature-band .eyebrow .dot{
  width:.38rem; height:.38rem; border-radius:999px; background:#10b981;
  box-shadow:0 0 0 4px rgba(16,185,129,.18);
}

/* slider shell */
.feature-slider{ position: relative; overflow: visible; }

/* ⬅️ KEY PART: let shadows bleed outside by adding inline padding on the viewport
   and countering it with negative margins so layout stays aligned. */
.slider-viewport{
  overflow: hidden;
  scroll-behavior: smooth;
  outline: none;
  padding-inline: clamp(12px, 3vw, 24px);
  margin-inline: calc(clamp(12px, 3vw, 24px) * -1);
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable both-edges;
  overscroll-behavior-inline: contain;
}

.slider-track{
  display:flex; gap:.75rem;
  padding: .25rem 0 .25rem;
  scroll-snap-type:x mandatory;
  will-change: transform;
}

/* slides & cards */
.slide{
  position: relative;               /* so z-index stacking is sane */
  flex:0 0 auto;
  width: clamp(240px, 30vw, 320px);
  scroll-snap-align: start;
  z-index: 0;
}
.slide:hover{ z-index: 3; }         /* rise above neighbors on hover */

.pro-card{
  display:grid; grid-template-columns: 40px auto; align-items:start;
  gap:.6rem; padding:.9rem;
  border:1px solid var(--border,rgba(0,0,0,.08));
  background:var(--surface,#fff);
  border-radius:var(--radius,16px);
  box-shadow: var(--shadow-sm, 0 4px 12px rgba(0,0,0,.06));
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease, background-color .2s ease;
  min-height: 160px;
  will-change: transform, box-shadow;
}
.pro-card:hover{
  transform: translateY(-2px);
  box-shadow: var(--shadow, 0 18px 44px rgba(0,0,0,.16)); /* richer, now visible outside */
  border-color: var(--border-strong, rgba(0,0,0,.14));
}

.pro-card .icon{
  width:40px; height:40px; border-radius:10px;
  display:grid; place-items:center;
  background: linear-gradient(135deg, rgba(99,102,241,.14), rgba(16,185,129,.12));
  border:1px solid var(--border,rgba(0,0,0,.08));
}
.pro-card .icon svg{ width:20px; height:20px; color:var(--text,#111214); }
.pro-card h3{ margin:0; font-weight:800; letter-spacing:-.01em; font-size:1rem; }
.pro-card p{
  grid-column:1 / -1; margin:.25rem 0 0; color:var(--muted,#6b7280);
  display:-webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow:hidden;
}

/* badge */
.pro-badge{
  display:inline-block; margin-left:.4rem;
  padding:.12rem .4rem; font-size:.68rem; font-weight:700; border-radius:999px;
  background:#eef2ff; color:#3730a3; border:1px solid #e0e7ff;
}

/* SPECIAL: Podcast card with background image + black overlay + white text */
.pro-card-hero{
  display:flex; flex-direction:column; justify-content:flex-end;
  grid-template-columns: none;
  padding: 1rem;
  min-height: 200px;
  color:#fff;
  background:#000;
  position: relative; overflow: hidden;
}
.pro-card-hero::before{
  content:"";
  position:absolute; inset:0;
  background-image: var(--hero-bg);
  background-size: cover; background-position: center;
  transform: scale(1.02);
  filter: saturate(110%);
}
.pro-card-hero::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.65));
}
.pro-card-hero > *{ position:relative; z-index:1; }
.pro-card-hero h3{ color:#fff; margin-bottom:.2rem; font-size:1rem; }
.pro-card-hero p{ color: rgba(255,255,255,.9); -webkit-line-clamp: 3; }

/* arrows */
.slider-arrows{ display:flex; gap:.5rem; }
.slider-arrow{
  width: 36px; height: 36px; border-radius: 999px;
  display:grid; place-items:center;
  border:1px solid var(--border,rgba(0,0,0,.08));
  background: var(--surface,#fff);
  box-shadow: var(--shadow-sm, 0 4px 12px rgba(0,0,0,.06));
}
.slider-arrow:hover{ box-shadow: var(--shadow, 0 18px 44px rgba(0,0,0,.12)); }
.slider-arrow[disabled]{ opacity:.45; pointer-events:none; }

/* dark mode */
@media (prefers-color-scheme: dark){
  .feature-band{ background:#0f1012; }
  .feature-band .eyebrow{ background:#101113; border-color:rgba(255,255,255,.1); color:#a0a7b4; }
  .pro-card{ background:#101113; border-color:rgba(255,255,255,.1); }
  .pro-card:hover{ border-color:rgba(255,255,255,.18); }
  .pro-badge{ background:#1f2440; color:#c7d2fe; border-color:#293057; }
}

          /* =========================
   Advertising — clean enterprise style (2 per row)
   ========================= */
.ad-band{
  position: relative;
  background: var(--surface-2, #f6f6f6);
  border-top: 1px solid var(--border, rgba(0,0,0,.08));
  isolation: isolate;
}

/* chips */
.ad-stats{ display:flex; flex-wrap:wrap; gap:.4rem .5rem; }
.ad-stats .chip{
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.25rem .55rem; font-size:.8rem; font-weight:600;
  border:1px solid var(--border, rgba(0,0,0,.08));
  border-radius:999px; background:var(--surface, #fff);
  color:var(--muted, #6b7280);
}
.ad-stats .chip .dot{
  width:.38rem; height:.38rem; border-radius:999px; background:#10b981;
  box-shadow:0 0 0 4px rgba(16,185,129,.18);
}

/* segmented control */
.ad-toggle{
  display:inline-flex; border:1px solid var(--border, rgba(0,0,0,.08));
  border-radius:999px; background:var(--surface, #fff);
  padding:.25rem; gap:.25rem;
}
.ad-toggle .seg{
  border:0; background:transparent; border-radius:999px;
  padding:.35rem .8rem; font-weight:700; font-size:.85rem; color:var(--muted, #6b7280);
}
.ad-toggle .seg.is-active{
  background:#eef2ff; color:#3730a3; box-shadow: inset 0 0 0 1px #e0e7ff;
}

/* note text */
.ad-note{ max-width: 52ch; }

/* placements grid — 1 col on mobile, 2 cols on ≥576px, and stays 2 cols on desktop */
.ad-grid{
  display:grid; gap:.75rem;
  grid-template-columns: 1fr;             /* mobile: 1 */
}
@media (min-width: 576px){
  .ad-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }  /* tablet/desktop: 2 */
}
/* (intentionally no 3-col breakpoint; remains 2 across at ≥992px) */

/* cards (compact) */
.ad-card{
  display:grid; grid-template-columns: 40px auto; gap:.6rem; align-items:start;
  padding:.8rem;                             /* tighter for less height */
  border:1px solid var(--border, rgba(0,0,0,.08));
  background: var(--surface, #fff);
  border-radius: var(--radius, 16px);
  box-shadow: var(--shadow-sm, 0 4px 12px rgba(0,0,0,.06));
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.ad-card:hover{
  transform: translateY(-2px);
  box-shadow: var(--shadow, 0 18px 44px rgba(0,0,0,.12));
  border-color: var(--border-strong, rgba(0,0,0,.14));
}

.ad-card .icon{
  width:40px; height:40px; border-radius:10px; display:grid; place-items:center;
  background: linear-gradient(135deg, rgba(99,102,241,.16), rgba(16,185,129,.14));
  border:1px solid var(--border, rgba(0,0,0,.08));
}
.ad-card .icon svg{ width:20px; height:20px; color: var(--text, #111214); }

.ad-card .ad-text h3{
  margin:0; font-weight:800; letter-spacing:-.01em; font-size: .98rem;  /* slightly smaller */
}
.ad-card .ad-text p{
  margin:.2rem 0 0; line-height:1.35; color: var(--muted, #6b7280);
  display:-webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; /* cap to 2 lines */
}

/* dark mode */
@media (prefers-color-scheme: dark){
  .ad-band{ background:#0f1012; }
  .ad-stats .chip{ background:#101113; border-color:rgba(255,255,255,.1); color:#a0a7b4; }
  .ad-toggle{ background:#101113; border-color:rgba(255,255,255,.1); }
  .ad-toggle .seg.is-active{ background:#1f2440; color:#c7d2fe; box-shadow: inset 0 0 0 1px #293057; }
  .ad-card{ background:#101113; border-color:rgba(255,255,255,.1); }
  .ad-card:hover{ border-color:rgba(255,255,255,.18); }
}


