:root {
  --pink:#f28482; --pink-light:#ffb5a7; --pink-dark:#c9504e;
  --yellow:#f6bd60; --yellow-dark:#e8a32a;
  --sage:#84a59d; --text:#3d405b; --muted:#9a8c98;
  --glass:rgba(255,255,255,.5); --glass-b:rgba(255,255,255,.72);

  /* Fluid spacing tokens — no media queries needed */
  --px:    clamp(16px, 4vw, 60px);
  --gap:   clamp(10px, 2vw, 22px);
  --gap-lg:clamp(28px, 5vw, 64px);
  --pad:   clamp(20px, 4vw, 52px);
  --r:     clamp(18px, 3vw, 28px);
}

*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; -webkit-tap-highlight-color:transparent }
html { -webkit-text-size-adjust:100%; scroll-behavior:smooth }
body {
  font-family:'Outfit',sans-serif; color:var(--text); width:100%; height:100%; overflow:hidden;
  background:linear-gradient(135deg,#fff5f5,#fffaf0 50%,#f0f7f4);
  -webkit-font-smoothing:antialiased;
}
body::before {
  content:''; position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(ellipse 60vw 50vh at 10% 20%,rgba(242,132,130,.15),transparent 60%),
    radial-gradient(ellipse 50vw 45vh at 88% 80%,rgba(246,189,96,.18),transparent 60%);
  animation:bgShift 14s ease-in-out infinite alternate;
}
body::after {
  content:''; position:fixed; inset:0; z-index:0; pointer-events:none;
  backdrop-filter:blur(60px); -webkit-backdrop-filter:blur(60px);
  background:rgba(255,255,255,0.45);
}
@keyframes bgShift { to { opacity:.8; transform:scale(1.08) rotate(2deg) } }

#bg-canvas { position:fixed; inset:0; z-index:1; pointer-events:none }

/* ── Petals ── */
.petal { position:fixed; z-index:2; pointer-events:none; opacity:0; animation:petalFall linear infinite }
@keyframes petalFall {
  0% { opacity:0; transform:translateY(-40px) rotate(0deg) }
  10% { opacity:1 }
  90% { opacity:.6 }
  100% { opacity:0; transform:translateY(105vh) rotate(720deg) }
}

/* ── Penguin ── */
#pengu { position:fixed; z-index:9990; pointer-events:none; will-change:transform; left:0; top:0 }
.pengu-body {
  width:clamp(36px,5vw,50px); height:clamp(44px,6vw,60px);
  background:#2d2d2d; border-radius:50% 50% 45% 45%;
  position:relative; box-shadow:0 4px 14px rgba(0,0,0,.25);
}
.pengu-belly {
  position:absolute; bottom:4px; left:50%; transform:translateX(-50%);
  width:68%; height:60%; background:#f0f0f0; border-radius:50% 50% 45% 45%;
}
.pengu-eye { position:absolute; top:22%; width:18%; height:22%; background:#fff; border-radius:50% }
.pengu-eye::after { content:''; position:absolute; top:28%; left:22%; width:52%; height:52%; background:#111; border-radius:50% }
.pengu-eye.left { left:16% }.pengu-eye.right { right:16% }
.pengu-beak {
  position:absolute; top:40%; left:50%; transform:translateX(-50%);
  width:0; height:0;
  border-left:5px solid transparent; border-right:5px solid transparent; border-top:7px solid #f6bd60;
}
.pengu-foot { position:absolute; bottom:-5px; width:26%; height:14%; background:#f6bd60; border-radius:50% }
.pengu-foot.left{left:10%}.pengu-foot.right{right:10%}
.pengu-speech {
  position:absolute; top:-34px; left:calc(100% + 8px);
  background:#fff; color:var(--text);
  padding:4px 10px; border-radius:12px; font-size:clamp(.65rem,1.5vw,.78rem);
  font-weight:600; white-space:nowrap; opacity:0; transition:opacity .3s;
  box-shadow:0 2px 10px rgba(0,0,0,.1); pointer-events:none;
}
.pengu-speech.show { opacity:1 }

/* ── Nav ── */
nav {
  position:fixed; bottom:clamp(14px,2.5vh,28px); left:50%; transform:translateX(-50%);
  z-index:999;
  background:var(--glass); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border:1.5px solid var(--glass-b); border-radius:50px;
  padding:clamp(5px,1vw,8px) clamp(8px,1.5vw,14px);
  box-shadow:0 8px 32px rgba(242,132,130,.15),0 2px 8px rgba(0,0,0,.06);
  display:flex; gap:clamp(2px,0.8vw,8px);
  max-width:calc(100vw - 20px);
}
.nav-btn {
  background:transparent; border:none; color:var(--text);
  font-family:'Outfit',sans-serif; font-weight:600;
  font-size:clamp(.72rem,2vw,1rem);
  padding:clamp(7px,1.2vw,11px) clamp(9px,2vw,22px);
  border-radius:40px; cursor:pointer; transition:all .3s;
  display:flex; align-items:center; gap:clamp(4px,.8vw,7px); white-space:nowrap;
}
.nav-btn i { font-size:clamp(.9rem,2.2vw,1.2rem) }
.nav-btn:hover,.nav-btn:active { background:rgba(255,255,255,.6); color:var(--pink) }
.nav-btn.active {
  background:linear-gradient(135deg,var(--pink),#e8706e); color:#fff;
  box-shadow:0 4px 14px rgba(242,132,130,.5);
}

/* ── Pages ── */
#app { position:fixed; inset:0; z-index:10 }
.page {
  position:absolute; inset:0;
  opacity:0; pointer-events:none;
  transform:translateY(22px) scale(.98);
  transition:opacity .45s cubic-bezier(.4,0,.2,1), transform .45s cubic-bezier(.4,0,.2,1);
}
.page.active { opacity:1; pointer-events:auto; transform:none }
.home-scroll {
  width:100%; height:100%;
  overflow-y:auto; overflow-x:hidden;
  padding:var(--gap-lg) var(--px) clamp(90px,14vh,120px);
  -webkit-overflow-scrolling:touch;
}
.home-scroll::-webkit-scrollbar { width:3px }
.home-scroll::-webkit-scrollbar-thumb { background:var(--pink-light); border-radius:2px }

/* ── Fluid container ── */
.section-block {
  width:min(860px, 100%);
  margin:var(--gap-lg) auto 0;
}
.section-title {
  font-family:'Playfair Display',serif;
  font-size:clamp(1.4rem,4vw,2.1rem);
  color:var(--pink); text-align:center; margin-bottom:6px;
}
.section-sub { text-align:center; color:var(--muted); font-size:clamp(.82rem,2vw,.98rem); line-height:1.55; margin-bottom:var(--gap) }

/* ────────────────────────────────
   HOME
──────────────────────────────── */
.hero {
  min-height:clamp(75vh,82vh,95vh);
  display:flex; align-items:center; justify-content:center; padding:var(--gap) 0;
}
.hero-card {
  background:var(--glass); backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  border:1.5px solid var(--glass-b); border-radius:var(--r);
  padding:var(--pad) clamp(22px,5vw,80px);
  width:100%; text-align:center;
  box-shadow:0 16px 50px rgba(0,0,0,.06),0 4px 14px rgba(242,132,130,.1);
  position:relative; overflow:hidden;
}
.hero-card::before {
  content:'🌻'; position:absolute; top:-10px; right:-10px;
  font-size:clamp(4rem,10vw,8rem); opacity:.06; animation:spin 20s linear infinite;
}
@keyframes spin { to { transform:rotate(360deg) } }
.home-badge {
  display:inline-block;
  background:linear-gradient(135deg,var(--pink-light),var(--yellow));
  color:#fff; font-size:clamp(.66rem,1.6vw,.78rem); font-weight:700;
  letter-spacing:2px; text-transform:uppercase;
  padding:clamp(4px,.8vw,6px) clamp(12px,2.5vw,18px); border-radius:30px;
  margin-bottom:clamp(14px,3vw,22px);
  box-shadow:0 4px 12px rgba(242,132,130,.3);
}
.hero-title {
  font-family:'Playfair Display',serif;
  font-size:clamp(1.9rem,6.5vw,4.4rem);
  color:var(--pink); line-height:1.15; margin-bottom:10px;
}
.hero-title .for { color:var(--text); font-style:italic; font-weight:400 }
.nick {
  display:inline-block; color:var(--yellow-dark);
  transition:opacity .4s,transform .4s;
  word-break:break-word; max-width:100%;
}
.nick.fading { opacity:0; transform:translateY(8px) }
.hero-desc {
  font-size:clamp(.88rem,2.4vw,1.15rem);
  color:var(--muted); margin:clamp(14px,3vw,22px) 0 clamp(22px,4vw,36px); line-height:1.7;
}
.hero-desc span { color:var(--pink); font-weight:600 }
.cta-row { display:flex; gap:clamp(8px,2vw,16px); justify-content:center; flex-wrap:wrap }
.cta {
  border:none; font-family:'Outfit',sans-serif; font-weight:700;
  font-size:clamp(.84rem,2.2vw,1.05rem); border-radius:50px; cursor:pointer;
  padding:clamp(11px,2vw,15px) clamp(18px,3.5vw,34px);
  transition:all .3s; display:flex; align-items:center; gap:7px;
  min-height:44px;
}
.cta.primary { background:linear-gradient(135deg,var(--pink),#e87270); color:#fff; box-shadow:0 6px 20px rgba(242,132,130,.45) }
.cta.primary:active { transform:scale(.96) }
.cta.secondary { background:linear-gradient(135deg,var(--yellow),var(--yellow-dark)); color:#fff; box-shadow:0 6px 20px rgba(246,189,96,.4) }
.cta.secondary:active { transform:scale(.96) }

/* Stats */
.stats-row { display:grid; grid-template-columns:repeat(auto-fit,minmax(min(130px,100%),1fr)); gap:var(--gap) }
.stat-card {
  background:var(--glass); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border:1.5px solid var(--glass-b); border-radius:var(--r);
  padding:clamp(16px,3vw,28px) clamp(10px,2vw,16px);
  text-align:center; box-shadow:0 6px 20px rgba(0,0,0,.05); transition:transform .3s;
}
.stat-card:hover { transform:translateY(-5px) }
.stat-icon { font-size:clamp(1.3rem,3.5vw,2rem); display:block; margin-bottom:6px }
.stat-num { font-family:'Playfair Display',serif; font-size:clamp(1.5rem,4vw,2.4rem); font-weight:700; color:var(--pink); display:block }
.stat-label { font-size:clamp(.6rem,1.4vw,.72rem); color:var(--muted); text-transform:uppercase; letter-spacing:.8px; margin-top:4px; display:block }

/* Flip Cards */
.cards-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(min(160px,100%),1fr)); gap:var(--gap) }
.flip-card { perspective:1000px; height:clamp(150px,22vw,200px); cursor:pointer }
.flip-inner { position:relative; width:100%; height:100%; transition:transform .6s; transform-style:preserve-3d }
.flip-card.flipped .flip-inner { transform:rotateY(180deg) }
.flip-front,.flip-back {
  position:absolute; inset:0; backface-visibility:hidden;
  border-radius:clamp(14px,2.5vw,20px);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:clamp(10px,2vw,18px); border:1.5px solid var(--glass-b);
  overflow:hidden;
}
.flip-front { background:var(--glass); backdrop-filter:blur(12px); box-shadow:0 6px 20px rgba(0,0,0,.05) }
.flip-front span { font-size:clamp(1.8rem,4vw,2.8rem); margin-bottom:8px }
.flip-front p { font-weight:700; font-size:clamp(.82rem,2vw,1rem); color:var(--text); text-align:center }
.flip-back {
  background:linear-gradient(135deg,var(--pink),var(--pink-dark));
  color:#fff; transform:rotateY(180deg);
  font-size:clamp(.74rem,1.8vw,.92rem); line-height:1.5; text-align:center;
}

/* Points Display */
.points-display {
  position:fixed; top:clamp(14px,2.5vh,28px); right:var(--px); z-index:999;
  background:rgba(255,255,255,0.85); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border:2px solid var(--yellow);
  color:var(--text); font-family:'Outfit',sans-serif; font-weight:800;
  padding:6px 14px 6px 6px;
  border-radius:40px; box-shadow:0 8px 25px rgba(246,189,96,.2);
  cursor:pointer; transition:all .3s; display:flex; align-items:center; gap:8px;
}
.points-display:hover { transform:scale(1.05); border-color:var(--yellow-dark); box-shadow:0 10px 30px rgba(246,189,96,.35); }
.wallet-icon {
  background:linear-gradient(135deg,var(--yellow),var(--yellow-dark)); color:#fff;
  width:clamp(30px,4vw,38px); height:clamp(30px,4vw,38px); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:clamp(1rem,2vw,1.2rem); box-shadow:0 4px 10px rgba(246,189,96,.4);
}
.wallet-text { font-size:clamp(.9rem,2vw,1.1rem); margin-right:4px; }

/* Food */
.food-row { display:flex; gap:var(--gap); justify-content:center; flex-wrap:wrap }
.food-btn {
  background:linear-gradient(135deg,var(--yellow),var(--yellow-dark)); color:#fff;
  border:none; padding:clamp(12px,2.5vw,18px) clamp(18px,3.5vw,36px); border-radius:50px;
  font-family:'Outfit',sans-serif; font-weight:700; font-size:clamp(.9rem,2.2vw,1.1rem);
  cursor:pointer; transition:all .3s; box-shadow:0 5px 16px rgba(246,189,96,.4);
  display:flex; align-items:center; gap:8px; min-height:44px;
}
.food-btn span { font-size:clamp(1.2rem,3vw,1.6rem) }
.food-btn:active { transform:scale(.93) }

/* Love Meter */
.love-meter { text-align:center; max-width:min(340px,100%) ; margin:0 auto }
.love-heart-btn { font-size:clamp(2.8rem,7vw,4rem); background:none; border:none; cursor:pointer; animation:heartPulse 1.5s ease-in-out infinite }
@keyframes heartPulse { 0%,100%{transform:scale(1)}50%{transform:scale(1.15)} }
.love-heart-btn:active { transform:scale(.85)!important }
.love-bar-wrap { background:rgba(0,0,0,.06); border-radius:20px; height:clamp(12px,2vw,18px); margin:14px 0; overflow:hidden }
.love-bar { height:100%; background:linear-gradient(90deg,var(--pink),var(--yellow),var(--pink)); border-radius:20px; transition:width .3s; width:0 }
.love-result { color:var(--pink); font-weight:700; font-size:clamp(.88rem,2.2vw,1.1rem); min-height:1.4em }

/* ────────────────────────────────
   PRODUCTIVITY
──────────────────────────────── */
.prod-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(min(280px,100%),1fr));
  gap:var(--gap);
}
.prod-card {
  background:var(--glass); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border:1.5px solid var(--glass-b); border-radius:var(--r);
  padding:var(--pad); box-shadow:0 10px 35px rgba(0,0,0,.06);
}
.prod-card h3 { font-family:'Playfair Display',serif; font-size:clamp(1.1rem,2.8vw,1.5rem); color:var(--pink); margin-bottom:4px }
.prod-sub { color:var(--muted); font-size:clamp(.78rem,1.8vw,.9rem); margin-bottom:clamp(12px,2.5vw,20px) }

/* Mood */
.mood-row { display:flex; justify-content:space-between; gap:var(--gap); flex-wrap:nowrap }
.mood-btn {
  flex:1; background:rgba(255,255,255,.6); border:2px solid transparent;
  border-radius:clamp(10px,2vw,16px); padding:clamp(8px,1.5vw,14px) 6px;
  display:flex; flex-direction:column; align-items:center; gap:5px;
  cursor:pointer; transition:all .25s; font-size:clamp(.6rem,1.4vw,.75rem);
  font-family:'Outfit',sans-serif; font-weight:600; color:var(--muted);
}
.mood-btn .m-emoji { font-size:clamp(1.4rem,3.5vw,2rem) }
.mood-btn:active,.mood-btn.selected { border-color:var(--pink); background:rgba(255,255,255,.9); color:var(--pink) }

/* Water */
.water-glasses { display:flex; gap:clamp(5px,1.2vw,10px); flex-wrap:wrap; justify-content:center; margin-bottom:10px }
.glass-btn {
  font-size:clamp(1.4rem,3.5vw,2rem); background:none; border:none;
  cursor:pointer; transition:transform .2s; line-height:1;
}
.glass-btn:active { transform:scale(.85) }
.glass-btn.filled { filter:saturate(2) }
.glass-btn.empty { filter:grayscale(1) opacity(.35) }
.water-label { text-align:center; color:var(--muted); font-size:clamp(.75rem,1.8vw,.88rem) }

/* Pomodoro */
.pomo-display {
  font-family:'Outfit',sans-serif; font-size:clamp(2.8rem,8vw,4.5rem);
  font-weight:800; color:var(--text); margin:clamp(10px,2vw,18px) 0; letter-spacing:2px; text-align:center;
}
.pomo-btns { display:flex; gap:var(--gap); justify-content:center; margin-bottom:clamp(10px,2vw,16px); flex-wrap:wrap }
.pomo-btns button {
  padding:clamp(8px,1.5vw,11px) clamp(16px,3vw,24px); border:none; border-radius:30px;
  font-family:'Outfit',sans-serif; font-weight:700; cursor:pointer;
  font-size:clamp(.82rem,2vw,.95rem); min-height:40px; transition:all .3s;
}
.pomo-btns button:first-child { background:var(--pink); color:#fff; box-shadow:0 4px 14px rgba(242,132,130,.4) }
.pomo-btns button:last-child { background:var(--glass-b); color:var(--text) }
.pomo-presets { display:flex; gap:clamp(5px,1vw,8px); justify-content:center; flex-wrap:wrap }
.preset {
  padding:clamp(5px,.8vw,7px) clamp(10px,2vw,16px); border:1.5px solid var(--glass-b);
  border-radius:20px; background:transparent; font-family:'Outfit',sans-serif;
  cursor:pointer; font-size:clamp(.72rem,1.8vw,.85rem); color:var(--muted); transition:all .3s; min-height:34px;
}
.preset.active { background:var(--pink-light); color:#fff; border-color:var(--pink-light) }

/* Habits */
.habits { display:grid; grid-template-columns:repeat(auto-fill,minmax(min(130px,100%),1fr)); gap:var(--gap) }
.habit-item {
  background:rgba(255,255,255,.75); border-radius:clamp(10px,2vw,16px);
  padding:clamp(10px,2vw,14px); display:flex; flex-direction:column; align-items:center;
  gap:5px; cursor:pointer; transition:all .3s; border:1.5px solid transparent; text-align:center; min-height:70px;
}
.habit-item:active { transform:scale(.96) }
.habit-item.done { opacity:.6; background:rgba(248,248,248,.7) }
.habit-item.done .habit-text { text-decoration:line-through; color:var(--muted) }
.habit-check {
  width:clamp(18px,3vw,24px); height:clamp(18px,3vw,24px); border-radius:50%;
  border:2px solid var(--pink-light); display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:.65rem; transition:all .25s;
}
.habit-item.done .habit-check { background:var(--pink); border-color:var(--pink) }
.habit-emoji { font-size:clamp(1.2rem,3vw,1.6rem) }
.habit-text { font-size:clamp(.72rem,1.6vw,.88rem); line-height:1.3 }

/* Weekly Goals */
.goals-list { display:flex; flex-direction:column; gap:clamp(8px,1.5vw,12px); margin-bottom:clamp(12px,2.5vw,18px) }
.goal-item {
  background:rgba(255,255,255,.75); border-radius:clamp(10px,2vw,14px);
  padding:clamp(10px,2vw,14px) clamp(12px,2.5vw,18px);
  display:flex; align-items:center; gap:10px; cursor:pointer;
  transition:all .28s; border:1.5px solid transparent; min-height:48px;
}
.goal-item:hover { border-color:var(--yellow) }
.goal-item.done { opacity:.6 }
.goal-item.done .goal-text { text-decoration:line-through; color:var(--muted) }
.goal-check {
  width:clamp(20px,3vw,26px); height:clamp(20px,3vw,26px); border-radius:50%;
  border:2px solid var(--yellow); display:flex; align-items:center; justify-content:center;
  color:#fff; flex-shrink:0; transition:all .25s; font-size:.75rem;
}
.goal-item.done .goal-check { background:var(--yellow); border-color:var(--yellow) }
.goal-text { flex:1; font-size:clamp(.85rem,2vw,1rem) }
.goal-del { background:none; border:none; color:#e07a5f; font-size:1.05rem; cursor:pointer; padding:4px; flex-shrink:0 }
.goal-add { display:flex; gap:8px }

/* Journal */
.journal-entries {
  display:flex; flex-direction:column; gap:clamp(6px,1.5vw,10px);
  margin-bottom:clamp(10px,2vw,16px); max-height:clamp(120px,22vh,200px); overflow-y:auto;
}
.journal-entry {
  background:rgba(255,255,255,.75); border-radius:clamp(8px,1.5vw,14px);
  padding:clamp(8px,1.5vw,12px) clamp(10px,2vw,16px);
  font-size:clamp(.8rem,1.8vw,.95rem); display:flex; align-items:flex-start; gap:8px;
  animation:slideIn .3s ease;
}
@keyframes slideIn { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:none} }

/* Generic Input Row */
.add-row { display:flex; gap:clamp(6px,1.5vw,10px) }
.add-input {
  flex:1; padding:clamp(10px,2vw,14px) clamp(14px,2.5vw,18px);
  border:2px solid var(--glass-b); border-radius:50px;
  background:rgba(255,255,255,.6); font-family:'Outfit',sans-serif;
  font-size:clamp(.82rem,2vw,.95rem); outline:none; transition:all .3s;
  color:var(--text); -webkit-appearance:none; appearance:none; min-height:44px;
}
.add-input::placeholder { color:var(--muted) }
.add-input:focus { background:#fff; border-color:var(--pink-light); box-shadow:0 0 16px rgba(255,181,167,.3) }
.add-btn {
  width:clamp(40px,6vw,48px); height:clamp(40px,6vw,48px); flex-shrink:0;
  border-radius:50%; border:none;
  background:linear-gradient(135deg,var(--yellow),var(--yellow-dark));
  color:#fff; font-size:clamp(1.1rem,2.5vw,1.4rem);
  cursor:pointer; transition:all .3s;
  box-shadow:0 4px 14px rgba(246,189,96,.4);
  display:flex; align-items:center; justify-content:center;
}
.add-btn:hover { transform:rotate(90deg) scale(1.1) }

/* Quote */
.quote-card {
  background:var(--glass); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border:1.5px solid var(--glass-b); border-radius:var(--r);
  padding:var(--pad); text-align:center;
}
.quote-card i { font-size:clamp(1.6rem,4vw,2.5rem); color:var(--pink-light); margin-bottom:8px; display:block }
.quote-card p {
  font-family:'Playfair Display',serif; font-size:clamp(.95rem,2.5vw,1.2rem);
  font-style:italic; color:var(--text); line-height:1.65; margin-bottom:14px;
}
.quote-refresh {
  background:var(--pink); color:#fff; border:none;
  padding:clamp(7px,1.5vw,9px) clamp(16px,3vw,22px); border-radius:20px;
  font-family:'Outfit',sans-serif; font-weight:600; cursor:pointer;
  font-size:clamp(.8rem,2vw,.92rem); transition:all .3s;
}
.quote-refresh:hover { transform:translateY(-2px); box-shadow:0 4px 12px rgba(242,132,130,.4) }

/* Daily Log */
.daily-log-card {
  background:linear-gradient(135deg,rgba(242,132,130,.1),rgba(246,189,96,.1));
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border:1.5px solid var(--glass-b); border-radius:var(--r);
  padding:var(--pad); box-shadow:0 10px 35px rgba(0,0,0,.06);
}
.daily-log-card h3 { font-family:'Playfair Display',serif; font-size:clamp(1.1rem,2.8vw,1.5rem); color:var(--pink); margin-bottom:4px }
.log-date { font-size:clamp(.68rem,1.5vw,.76rem); color:var(--muted); font-weight:600; letter-spacing:1px; text-transform:uppercase; margin-bottom:clamp(10px,2vw,14px) }
.log-stats { display:grid; grid-template-columns:repeat(auto-fit,minmax(min(110px,100%),1fr)); gap:var(--gap) }
.log-stat {
  background:rgba(255,255,255,.7); border-radius:clamp(10px,2vw,14px);
  padding:clamp(10px,2vw,16px) clamp(8px,1.5vw,12px);
  display:flex; align-items:center; gap:8px;
}
.log-stat-icon { font-size:clamp(1.3rem,3vw,1.7rem); flex-shrink:0 }
.log-stat-num { font-weight:800; font-size:clamp(1rem,2.8vw,1.3rem); color:var(--pink); display:block }
.log-stat-label { font-size:clamp(.6rem,1.4vw,.73rem); color:var(--muted) }
.log-history-btn {
  margin-top:clamp(10px,2vw,14px); background:none;
  border:1.5px solid var(--pink-light); color:var(--pink);
  font-family:'Outfit',sans-serif; font-weight:600;
  font-size:clamp(.76rem,1.8vw,.84rem); padding:7px 16px; border-radius:20px;
  cursor:pointer; transition:all .3s;
}
.log-history-btn:active { background:var(--pink-light); color:#fff }
.history-sheet {
  display:none; margin-top:clamp(10px,2vw,14px);
  max-height:clamp(160px,28vh,200px); overflow-y:auto;
  flex-direction:column; gap:8px;
}
.history-sheet.open { display:flex }
.history-row {
  background:rgba(255,255,255,.7); border-radius:clamp(8px,1.5vw,12px);
  padding:clamp(8px,1.5vw,12px); font-size:clamp(.76rem,1.8vw,.84rem);
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:6px;
}
.hr-date { color:var(--muted); font-size:clamp(.68rem,1.4vw,.76rem) }
.hr-stats { display:flex; gap:6px; flex-wrap:wrap }
.hr-badge {
  background:linear-gradient(135deg,var(--pink-light),var(--yellow));
  color:#fff; font-weight:700; font-size:clamp(.62rem,1.4vw,.72rem);
  padding:2px 8px; border-radius:10px;
}

/* ────────────────────────────────
   TODO
──────────────────────────────── */
.todo-header { text-align:center; margin:var(--gap-lg) auto var(--gap); width:min(720px,100%) }
.todo-header h2 { font-family:'Playfair Display',serif; font-size:clamp(1.6rem,5vw,2.4rem); color:var(--yellow-dark); margin-bottom:6px }
.todo-header p { color:var(--muted); font-size:clamp(.82rem,2vw,.98rem) }
.todo-card {
  background:var(--glass); backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  border:1.5px solid var(--glass-b); border-radius:var(--r);
  padding:var(--pad); box-shadow:0 14px 40px rgba(0,0,0,.07);
  width:min(720px,100%); margin:0 auto;
}
.todo-progress { background:rgba(255,255,255,.5); border-radius:12px; height:clamp(6px,1.2vw,8px); margin-bottom:clamp(14px,2.5vw,22px); overflow:hidden }
.todo-progress-bar { height:100%; background:linear-gradient(90deg,var(--pink),var(--yellow)); border-radius:12px; transition:width .5s cubic-bezier(.4,0,.2,1) }
.todo-progress-label { font-size:clamp(.72rem,1.5vw,.8rem); color:var(--muted); text-align:right; margin-bottom:8px }
.todo-list { display:flex; flex-direction:column; gap:clamp(8px,1.5vw,12px); margin-bottom:clamp(14px,2.5vw,22px) }
.todo-item {
  background:rgba(255,255,255,.85); border-radius:clamp(10px,2vw,16px);
  padding:clamp(11px,2vw,15px) clamp(12px,2.5vw,18px);
  display:flex; align-items:center; gap:clamp(10px,2vw,14px);
  cursor:pointer; transition:all .28s; border:1.5px solid transparent; min-height:50px;
}
.todo-item:hover { transform:translateX(5px); border-color:var(--pink-light); box-shadow:0 6px 20px rgba(242,132,130,.12) }
.todo-item.done { opacity:.65; background:rgba(248,248,248,.7) }
.todo-item.done .todo-text { text-decoration:line-through; color:var(--muted) }
.todo-check {
  width:clamp(22px,3.5vw,26px); height:clamp(22px,3.5vw,26px);
  border-radius:50%; border:2px solid var(--pink-light);
  display:flex; align-items:center; justify-content:center;
  color:#fff; flex-shrink:0; transition:all .25s; font-size:.8rem;
}
.todo-item.done .todo-check { background:linear-gradient(135deg,var(--pink),var(--pink-dark)); border-color:var(--pink) }
.todo-emoji { font-size:clamp(1.1rem,2.5vw,1.3rem); flex-shrink:0 }
.todo-text { flex:1; font-size:clamp(.88rem,2vw,1.05rem); line-height:1.4; word-break:break-word }
.todo-del { background:none; border:none; color:#e07a5f; font-size:1.1rem; cursor:pointer; padding:4px; flex-shrink:0; opacity:0; transition:all .2s }
.todo-item:hover .todo-del { opacity:1 }

/* ── Effects ── */
.confetti { position:fixed; top:-20px; pointer-events:none; z-index:9999; border-radius:50%; animation:cFall linear forwards }
@keyframes cFall { 0%{transform:translateY(0) rotate(0) scale(1);opacity:1} 100%{transform:translateY(110vh) rotate(720deg) scale(0);opacity:0} }
.heart-burst { position:fixed; pointer-events:none; z-index:9998; font-size:clamp(1rem,2.5vw,1.4rem); animation:hBurst .8s ease forwards }
@keyframes hBurst { 0%{opacity:1;transform:translate(-50%,-50%) scale(.5)} 50%{opacity:1;transform:translate(-50%,-50%) scale(1.4)} 100%{opacity:0;transform:translate(-50%,-150%) scale(1)} }
.cursor-sparkle { position:fixed; pointer-events:none; z-index:9997; width:7px; height:7px; border-radius:50%; animation:sFade .6s ease forwards }
@keyframes sFade { 0%{opacity:.9;transform:scale(1)} 100%{opacity:0;transform:scale(0)} }

/* ────────────────────────────────
   REWARDS SHOP
──────────────────────────────── */
.reward-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:var(--gap);
  margin-bottom:var(--gap-lg); padding:0 clamp(10px,2vw,20px);
}
.reward-card {
  background:var(--glass); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border:1.5px solid var(--glass-b); border-radius:var(--r);
  padding:clamp(20px,3vw,30px); text-align:center;
  box-shadow:0 10px 35px rgba(0,0,0,.06);
  transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  display:flex; flex-direction:column; justify-content:space-between;
}
.reward-card:hover {
  transform:translateY(-6px);
  box-shadow:0 16px 45px rgba(246,189,96,.2);
  border-color:var(--yellow); cursor:pointer;
}
.reward-icon {
  font-size:clamp(3.5rem,6vw,4.5rem); margin-bottom:12px;
  animation:float 4s ease-in-out infinite;
}
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }
.reward-title {
  font-family:'Playfair Display',serif; font-size:clamp(1.2rem,3vw,1.5rem);
  color:var(--pink); margin-bottom:10px; font-weight:700;
}
.reward-cost {
  color:var(--text); font-family:'Outfit',sans-serif; font-weight:700;
  background:rgba(255,255,255,0.7); display:inline-block;
  padding:6px 16px; border-radius:30px; margin:0 auto 20px; font-size:1rem;
}
.reward-btn {
  background:linear-gradient(135deg,var(--yellow),var(--yellow-dark));
  color:#fff; border:none; padding:12px 24px; border-radius:30px;
  font-family:'Outfit',sans-serif; font-weight:800; font-size:clamp(.9rem,2vw,1.05rem);
  cursor:pointer; transition:all .3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow:0 6px 18px rgba(246,189,96,.35);
  display:flex; align-items:center; justify-content:center; gap:8px; margin:0 auto; width:100%; max-width:220px;
  text-transform:uppercase; letter-spacing:0.5px;
}
.reward-btn:hover {
  transform:translateY(-3px) scale(1.02); box-shadow:0 10px 25px rgba(246,189,96,.5);
}
.reward-btn:active { transform:translateY(1px) }
.reward-btn.custom-wish-btn {
  background:linear-gradient(135deg,var(--pink),var(--pink-dark));
  box-shadow:0 6px 18px rgba(242,132,130,.35);
}
.reward-btn.custom-wish-btn:hover { box-shadow:0 10px 25px rgba(242,132,130,.5); }
.wish-item {
  background:rgba(255,255,255,0.8); border:1px solid var(--glass-b);
  border-left:4px solid var(--pink); border-radius:12px;
  padding:12px 16px; text-align:left; font-size:0.9rem;
}

/* ────────────────────────────────
   QUICK WINS / MINI TASKS
──────────────────────────────── */
.quick-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:var(--gap);
  margin-bottom:var(--gap-lg); padding:0 clamp(10px,2vw,20px);
}
.quick-card {
  background:var(--glass); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border:1.5px solid var(--glass-b); border-radius:var(--r);
  padding:clamp(16px,2.5vw,24px); text-align:left;
  box-shadow:0 8px 25px rgba(0,0,0,.05);
  display:flex; flex-direction:column; justify-content:space-between;
  transition:all 0.3s;
}
.quick-card:hover { transform:translateY(-4px); border-color:var(--yellow); box-shadow:0 12px 30px rgba(246,189,96,.15); }
.quick-card.s-completed { border-color:var(--sage); background:linear-gradient(135deg,rgba(132,165,157,.08),rgba(246,189,96,.05)); }
.quick-category { font-size:0.75rem; color:var(--pink); font-weight:800; text-transform:uppercase; letter-spacing:1px; margin-bottom:8px; }
.quick-title { font-family:'Playfair Display',serif; font-size:1.2rem; color:var(--text); margin-bottom:6px; font-weight:700; }
.quick-desc { font-size:0.85rem; color:var(--muted); margin-bottom:16px; line-height:1.5; flex-grow:1; }
.quick-btn {
  background:linear-gradient(135deg,var(--yellow),var(--yellow-dark)); color:#fff; border:none;
  padding:10px 16px; border-radius:24px; font-family:'Outfit',sans-serif; font-weight:700;
  cursor:pointer; display:flex; align-items:center; justify-content:center; gap:6px; transition:all 0.3s;
}
.quick-btn:hover { transform:scale(1.03); box-shadow:0 6px 16px rgba(246,189,96,.3); }
.quick-btn:active { transform:scale(0.97); }
.quick-card.s-completed .quick-btn { background:rgba(132,165,157,.2); color:var(--sage); border:1px solid rgba(132,165,157,.4); box-shadow:none; cursor:default; }
.quick-card.s-completed .quick-btn:hover { transform:none; }

/* ════════════════════════════════════════════════════════════
   CREATIVE STUDIO — BRAND MISSIONS
   New section, appended below — zero existing rules modified
════════════════════════════════════════════════════════════ */

/* ── Float Point (shared effect used by studio completion) ── */
.float-point {
  position:fixed; pointer-events:none; z-index:9998;
  font-family:'Outfit',sans-serif; font-weight:800; font-size:1.1rem;
  color:var(--yellow-dark); animation:floatUp .9s ease-out forwards;
  text-shadow:0 2px 6px rgba(0,0,0,.15);
}
@keyframes floatUp { 0%{opacity:1;transform:translateY(0)} 100%{opacity:0;transform:translateY(-60px)} }

/* ── Mobile Nav (5 buttons) ── */
@media (max-width: 530px) {
  nav {
    overflow-x:auto; -webkit-overflow-scrolling:touch;
    scrollbar-width:none; border-radius:20px;
    justify-content:flex-start;
  }
  nav::-webkit-scrollbar { display:none }
}

/* ── Studio Phase Badge ── */
.studio-phase-badge {
  display:inline-block;
  font-size:clamp(.64rem,1.5vw,.76rem); font-weight:800;
  letter-spacing:1.5px; text-transform:uppercase;
  padding:5px 18px; border-radius:30px; border:1.5px solid;
  transition:all .4s ease;
}

/* ── Encourage line ── */
.studio-encourage {
  font-family:'Playfair Display',serif; font-style:italic;
  font-size:clamp(.9rem,2.2vw,1.1rem); color:var(--sage);
  margin-top:8px; text-align:center;
}

/* ── Stats Row ── */
.studio-stats-row {
  display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gap);
}
.studio-stat-card {
  background:var(--glass); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border:1.5px solid var(--glass-b); border-radius:var(--r);
  padding:clamp(14px,2.5vw,22px); text-align:center;
  box-shadow:0 6px 20px rgba(0,0,0,.05); transition:transform .3s;
}
.studio-stat-card:hover { transform:translateY(-4px) }
.studio-stat-num {
  font-family:'Playfair Display',serif;
  font-size:clamp(1.5rem,4vw,2.2rem); font-weight:700;
  color:var(--sage); display:block; margin-bottom:4px;
}
.studio-stat-label {
  font-size:clamp(.6rem,1.4vw,.72rem); color:var(--muted);
  text-transform:uppercase; letter-spacing:.8px;
}

/* ── Phase Progress Card ── */
.studio-phase-card {
  background:var(--glass); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border:1.5px solid var(--glass-b); border-radius:var(--r);
  padding:var(--pad); box-shadow:0 8px 28px rgba(0,0,0,.06);
}
.studio-phase-header {
  display:flex; justify-content:space-between;
  align-items:flex-start; gap:12px;
  margin-bottom:14px; flex-wrap:wrap;
}
.studio-phase-title {
  font-family:'Playfair Display',serif;
  font-size:clamp(1.1rem,2.8vw,1.4rem); color:var(--text); margin-bottom:3px;
}
.studio-phase-desc { font-size:clamp(.78rem,1.8vw,.9rem); color:var(--muted) }
.studio-phase-next {
  font-size:clamp(.72rem,1.6vw,.82rem); color:var(--sage);
  font-weight:700; white-space:nowrap;
}
.studio-phase-bar-bg {
  background:rgba(0,0,0,.06); border-radius:20px;
  height:clamp(8px,1.5vw,12px); overflow:hidden;
}
.studio-phase-bar-fill { height:100%; border-radius:20px; transition:width .8s cubic-bezier(.4,0,.2,1) }

/* ── Mission Tabs ── */
.studio-tabs {
  display:flex; gap:clamp(4px,1vw,8px);
  margin-bottom:clamp(14px,2.5vw,20px);
  background:var(--glass); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border:1.5px solid var(--glass-b); border-radius:50px; padding:5px;
  box-shadow:0 4px 16px rgba(0,0,0,.05);
}
.s-tab-btn {
  flex:1; background:transparent; border:none;
  padding:clamp(8px,1.5vw,11px) clamp(8px,1.5vw,16px);
  border-radius:40px; font-family:'Outfit',sans-serif;
  font-weight:600; font-size:clamp(.7rem,1.7vw,.86rem);
  color:var(--muted); cursor:pointer; transition:all .3s;
  white-space:nowrap; min-height:36px;
}
.s-tab-btn.s-tab-active {
  background:linear-gradient(135deg,var(--sage),#6b9e95);
  color:#fff; box-shadow:0 4px 14px rgba(132,165,157,.4);
}
.s-tab-btn:not(.s-tab-active):hover { color:var(--sage); background:rgba(132,165,157,.08) }

/* ── Tab Panels ── */
.s-tab-panels { position:relative }
.s-tab-panel { display:none }
.s-tab-panel.s-active { display:block }

/* ── Mission Card ── */
.s-mission-card {
  background:var(--glass); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border:1.5px solid var(--glass-b); border-radius:var(--r);
  padding:var(--pad); box-shadow:0 12px 40px rgba(0,0,0,.07);
  transition:box-shadow .3s; overflow:hidden;
}
.s-mission-card.main { border-top:3px solid var(--sage) }
.s-mission-card.easy { border-top:3px solid var(--yellow) }
.s-mission-card.exp  { border-top:3px solid var(--pink) }
.s-mission-card.s-completed {
  border-color:var(--sage);
  background:linear-gradient(135deg,rgba(132,165,157,.08),rgba(246,189,96,.05));
}

/* Type / Diff / Category chips */
.s-type-row { display:flex; align-items:center; gap:7px; flex-wrap:wrap; margin-bottom:12px }
.s-type-chip {
  font-size:clamp(.64rem,1.4vw,.74rem); font-weight:700; color:var(--sage);
  background:rgba(132,165,157,.13); padding:3px 10px; border-radius:20px; letter-spacing:.5px;
}
.s-diff-badge {
  font-size:clamp(.6rem,1.3vw,.72rem); font-weight:700; padding:3px 10px; border-radius:20px;
}
.s-cat-badge {
  font-size:clamp(.6rem,1.3vw,.72rem); color:var(--muted);
  background:rgba(0,0,0,.05); padding:3px 10px; border-radius:20px;
}

/* Mission title */
.s-mission-title {
  font-family:'Playfair Display',serif;
  font-size:clamp(1.2rem,3.2vw,1.7rem); color:var(--text);
  margin-bottom:12px; line-height:1.2;
}

/* Brand info row */
.s-brand-row {
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;
  margin-bottom:12px; padding:10px 14px;
  background:rgba(255,255,255,.6); border-radius:12px;
  border:1px solid var(--glass-b);
}
.s-brand-badge {
  font-size:.66rem; font-weight:800; letter-spacing:1px;
  text-transform:uppercase; padding:3px 10px; border-radius:20px;
}
.s-brand-badge.real    { background:rgba(246,189,96,.14); color:var(--yellow-dark); border:1px solid rgba(246,189,96,.3) }
.s-brand-badge.fictional { background:rgba(132,165,157,.14); color:var(--sage); border:1px solid rgba(132,165,157,.3) }
.s-brand-name { font-weight:800; font-size:clamp(.86rem,2vw,.98rem); color:var(--text) }
.s-brand-ind  { font-size:clamp(.7rem,1.5vw,.8rem); color:var(--muted) }
.s-brand-desc { width:100%; margin:4px 0 0; font-size:clamp(.7rem,1.5vw,.8rem); color:var(--muted); font-style:italic }

/* Goal text */
.s-mission-goal {
  font-size:clamp(.86rem,2vw,.98rem); color:var(--text); line-height:1.65; margin-bottom:0;
}

/* Expanded details */
.s-mission-details {
  display:none; margin-top:clamp(16px,2.5vw,22px);
  padding-top:clamp(16px,2.5vw,22px);
  border-top:1px solid rgba(0,0,0,.06);
  flex-direction:column; gap:clamp(12px,2.2vw,18px);
}
.s-mission-details.s-visible { display:flex }

.s-section {
  background:rgba(255,255,255,.55); border-radius:clamp(10px,2vw,16px);
  padding:clamp(12px,2.2vw,18px);
}
.s-direction-section {
  background:linear-gradient(135deg,rgba(132,165,157,.08),rgba(246,189,96,.05));
  border:1px solid rgba(132,165,157,.2);
}
.s-section-label {
  font-size:clamp(.66rem,1.4vw,.74rem); font-weight:800;
  letter-spacing:1.2px; text-transform:uppercase; color:var(--sage); margin-bottom:8px;
}
.s-section-body {
  font-size:clamp(.83rem,2vw,.96rem); color:var(--text); line-height:1.65;
}
.s-vibe-tags { display:flex; gap:6px; flex-wrap:wrap }
.s-vibe-tag {
  background:rgba(132,165,157,.12); color:var(--sage);
  font-size:clamp(.64rem,1.4vw,.74rem); font-weight:700; padding:3px 10px; border-radius:20px;
}
.s-deliverable {
  padding:5px 0; border-bottom:1px solid rgba(0,0,0,.05);
  font-size:clamp(.8rem,1.9vw,.93rem);
}
.s-deliverable:last-child { border-bottom:none }
.s-direction-text {
  font-family:'Playfair Display',serif; font-style:italic;
  color:var(--text); font-size:clamp(.88rem,2vw,1.02rem); line-height:1.7;
}
.s-tagline-box {
  font-family:'Playfair Display',serif; font-size:clamp(1rem,2.5vw,1.18rem);
  font-weight:700; color:var(--sage); text-align:center; padding:6px 0;
}
.s-steps { padding-left:18px; display:flex; flex-direction:column; gap:8px }
.s-steps li { font-size:clamp(.8rem,1.9vw,.94rem); line-height:1.55; color:var(--text) }

/* AI Prompt block */
.s-ai-prompt-box {
  background:linear-gradient(135deg,rgba(155,114,207,.06),rgba(132,165,157,.05));
  border:1px solid rgba(155,114,207,.2); border-radius:12px;
  padding:clamp(12px,2vw,16px);
}
.s-ai-prompt-text {
  font-size:clamp(.78rem,1.8vw,.9rem); color:var(--text);
  line-height:1.6; margin-bottom:10px; font-style:italic;
}
.s-ai-copy-btn {
  background:rgba(155,114,207,.12); color:#9b72cf;
  border:1px solid rgba(155,114,207,.3); padding:6px 16px; border-radius:20px;
  font-family:'Outfit',sans-serif; font-weight:700;
  font-size:clamp(.7rem,1.6vw,.8rem); cursor:pointer; transition:all .3s;
}
.s-ai-copy-btn:hover { background:rgba(155,114,207,.22) }

/* Card action zone */
.s-card-actions {
  margin-top:clamp(16px,2.5vw,22px); padding-top:clamp(14px,2vw,18px);
  border-top:1px solid rgba(0,0,0,.06);
}
.s-ai-prompt-input {
  width:100%; padding:10px 14px; border-radius:12px; border:1px dashed var(--sage);
  background:rgba(255,255,255,0.5); font-family:'Outfit',sans-serif; margin-bottom:12px;
  font-size:0.9rem; color:var(--text); outline:none; transition:border 0.3s;
}
.s-ai-prompt-input:focus { border-style:solid; background:#fff; border-color:var(--pink); }

.s-expand-btn {
  width:100%; background:rgba(132,165,157,.07);
  border:1.5px dashed rgba(132,165,157,.4); border-radius:12px;
  padding:clamp(10px,1.8vw,13px); font-family:'Outfit',sans-serif;
  font-weight:600; font-size:clamp(.8rem,2vw,.93rem); color:var(--sage);
  cursor:pointer; transition:all .3s;
  display:flex; align-items:center; justify-content:center; gap:6px; margin-bottom:12px;
}
.s-expand-btn:hover { background:rgba(132,165,157,.14); border-style:solid }
.s-action-row { display:flex; gap:clamp(8px,1.5vw,12px) }
.s-complete-btn {
  flex:1; background:linear-gradient(135deg,var(--sage),#6b9e95); color:#fff; border:none;
  padding:clamp(12px,2vw,15px) clamp(16px,3vw,24px); border-radius:50px;
  font-family:'Outfit',sans-serif; font-weight:700;
  font-size:clamp(.84rem,2vw,.97rem); cursor:pointer; transition:all .3s;
  box-shadow:0 5px 18px rgba(132,165,157,.4);
  display:flex; align-items:center; justify-content:center; gap:7px; min-height:46px;
}
.s-complete-btn:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(132,165,157,.5) }
.s-complete-btn:active { transform:scale(.97) }
.s-skip-btn {
  background:rgba(0,0,0,.04); border:1.5px solid rgba(0,0,0,.1); color:var(--muted);
  padding:clamp(10px,2vw,14px) clamp(14px,2.5vw,20px); border-radius:50px;
  font-family:'Outfit',sans-serif; font-weight:600;
  font-size:clamp(.76rem,1.8vw,.86rem); cursor:pointer; transition:all .3s;
  display:flex; align-items:center; gap:5px; min-height:46px; white-space:nowrap;
}
.s-skip-btn:hover { background:rgba(0,0,0,.07); color:var(--text) }
.s-done-badge {
  background:linear-gradient(135deg,rgba(132,165,157,.14),rgba(246,189,96,.1));
  border:1.5px solid rgba(132,165,157,.35); border-radius:12px;
  padding:clamp(10px,2vw,14px); text-align:center;
  font-weight:700; font-size:clamp(.82rem,2vw,.95rem); color:var(--sage);
}
.s-mission-empty {
  background:var(--glass); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border:1.5px dashed rgba(0,0,0,.12); border-radius:var(--r);
  padding:clamp(30px,5vw,50px) clamp(20px,4vw,40px);
  text-align:center; color:var(--muted); font-size:clamp(.88rem,2vw,1rem);
}
.s-mission-empty small { font-size:.85em; display:block; margin-top:6px }

/* ── Portfolio ── */
.studio-portfolio-msg {
  text-align:center; padding:10px 16px;
  margin-bottom:clamp(12px,2.5vw,20px);
  font-size:clamp(.85rem,2vw,.99rem); color:var(--yellow-dark);
  font-weight:700; background:rgba(246,189,96,.1);
  border-radius:12px; border:1px solid rgba(246,189,96,.25);
}
.studio-portfolio-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(190px,100%),1fr));
  gap:var(--gap);
}
.s-portfolio-item {
  background:var(--glass); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border:1.5px solid var(--glass-b); border-radius:clamp(14px,2.5vw,20px);
  padding:clamp(14px,2.5vw,20px); box-shadow:0 6px 20px rgba(0,0,0,.05);
  transition:all .3s; animation:slideIn .35s ease both;
}
.s-portfolio-item:hover {
  transform:translateY(-4px); box-shadow:0 12px 32px rgba(132,165,157,.15);
  border-color:var(--sage);
}
.s-pi-top { display:flex; justify-content:space-between; align-items:center; margin-bottom:6px }
.s-pi-cat {
  font-size:clamp(.58rem,1.3vw,.7rem); color:#fff; background:var(--sage);
  padding:2px 8px; border-radius:10px; font-weight:700;
}
.s-pi-date { font-size:clamp(.58rem,1.2vw,.68rem); color:var(--muted) }
.s-pi-diff {
  font-size:clamp(.58rem,1.2vw,.68rem); font-weight:700;
  text-transform:uppercase; letter-spacing:.6px; margin-bottom:4px;
}
.s-pi-title {
  font-family:'Playfair Display',serif;
  font-size:clamp(.9rem,2.2vw,1.06rem); color:var(--text); margin-bottom:4px; line-height:1.3;
}
.s-pi-brand { font-size:clamp(.7rem,1.6vw,.8rem); color:var(--muted); margin-bottom:8px }
.s-pi-tags  { display:flex; flex-wrap:wrap; gap:4px }
.s-pi-tag   {
  font-size:clamp(.56rem,1.2vw,.66rem); color:var(--sage);
  background:rgba(132,165,157,.1); padding:2px 7px; border-radius:8px;
}
.s-portfolio-empty {
  grid-column:1/-1; text-align:center;
  padding:clamp(30px,5vw,50px); color:var(--muted);
  font-size:clamp(.88rem,2vw,1rem);
  border:1.5px dashed rgba(0,0,0,.1); border-radius:var(--r);
  background:rgba(255,255,255,.3);
}
.s-portfolio-empty small { display:block; margin-top:6px; font-size:.85em }

/* ── Studio Toast Notification ── */
.studio-toast {
  position:fixed; bottom:clamp(90px,15vh,120px); left:50%;
  transform:translateX(-50%) translateY(30px); opacity:0;
  background:rgba(255,255,255,.93); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border:1.5px solid rgba(132,165,157,.4); border-radius:50px;
  padding:clamp(10px,2vw,14px) clamp(18px,3vw,26px);
  display:flex; align-items:center; gap:12px;
  box-shadow:0 8px 30px rgba(0,0,0,.14); z-index:9999;
  transition:all .4s cubic-bezier(.4,0,.2,1);
  white-space:nowrap; max-width:calc(100vw - 32px);
}
.studio-toast.st-show { opacity:1; transform:translateX(-50%) translateY(0) }
.st-icon { font-size:1.4rem }
.st-body { display:flex; flex-direction:column; gap:2px }
.st-msg { font-weight:700; font-size:clamp(.82rem,2vw,.94rem); color:var(--text) }
.st-pts { font-size:clamp(.7rem,1.6vw,.8rem); color:var(--yellow-dark); font-weight:700 }

/* ══════════════════════════════════════════════════════════
   TASK BRIEF MODAL — Full-screen immersive task view
════════════════════════════════════════════════════════════ */
.task-modal-overlay {
  position:fixed; inset:0; z-index:10000;
  background:rgba(61,64,91,.45); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  display:none; align-items:center; justify-content:center;
  padding:clamp(12px,3vw,24px);
  animation: modalFadeIn .25s ease;
}
.task-modal-overlay.active { display:flex }
@keyframes modalFadeIn { from{opacity:0} to{opacity:1} }

.task-modal-content {
  background:rgba(255,255,255,.96); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-radius:clamp(18px,3vw,26px); border:1.5px solid var(--glass-b);
  padding:clamp(20px,4vw,36px); max-width:min(600px,100%);
  width:100%; max-height:90vh; overflow-y:auto;
  box-shadow:0 24px 80px rgba(0,0,0,.22);
  position:relative;
  animation: modalSlideUp .3s cubic-bezier(.4,0,.2,1);
}
@keyframes modalSlideUp { from{transform:translateY(30px);opacity:0} to{transform:translateY(0);opacity:1} }

.task-modal-content::-webkit-scrollbar { width:5px }
.task-modal-content::-webkit-scrollbar-thumb { background:var(--sage); border-radius:10px }

.task-modal-close {
  position:absolute; top:14px; right:14px;
  width:36px; height:36px; border-radius:50%;
  background:rgba(0,0,0,.06); border:none; color:var(--text);
  font-size:1.2rem; cursor:pointer; transition:all .25s;
  display:flex; align-items:center; justify-content:center;
}
.task-modal-close:hover { background:rgba(242,132,130,.15); color:var(--pink) }

/* ══════════════════════════════════════════════════════════
   MINI TASK CARDS (quick-grid inside Mini Tasks tab)
════════════════════════════════════════════════════════════ */
.quick-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(280px,100%),1fr));
  gap:var(--gap);
  padding-top:clamp(12px,2vw,18px);
}

.quick-card {
  background:var(--glass); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border:1.5px solid var(--glass-b); border-radius:var(--r);
  padding:clamp(16px,3vw,22px);
  box-shadow:0 8px 28px rgba(0,0,0,.06);
  transition:all .3s; display:flex; flex-direction:column;
  justify-content:space-between; gap:12px;
}
.quick-card:hover { transform:translateY(-4px); box-shadow:0 14px 40px rgba(132,165,157,.18) }
.quick-card.s-completed {
  border-color:var(--sage);
  background:linear-gradient(135deg,rgba(132,165,157,.09),rgba(246,189,96,.05));
}

.quick-category {
  display:inline-block;
  font-size:clamp(.6rem,1.4vw,.72rem); font-weight:800;
  letter-spacing:.8px; text-transform:uppercase;
  color:var(--sage); background:rgba(132,165,157,.12);
  padding:3px 10px; border-radius:20px; margin-bottom:8px;
}
.quick-title {
  font-family:'Playfair Display',serif;
  font-size:clamp(1rem,2.6vw,1.25rem); color:var(--text);
  margin-bottom:6px; line-height:1.3; font-weight:700;
}
.quick-desc {
  font-size:clamp(.78rem,1.8vw,.9rem); color:var(--muted);
  line-height:1.55; margin-bottom:10px;
}

/* ════════════════════════════════════════════════════════════
   STUDIO — MOBILE RESPONSIVE FIXES
   Ensures Studio tab looks identical & usable on all devices
════════════════════════════════════════════════════════════ */

/* Tab bar: scroll horizontally on small screens */
@media (max-width: 600px) {
  .studio-tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    flex-wrap: nowrap;
    justify-content: flex-start;
    border-radius: 16px;
    padding: 4px;
    gap: 4px;
  }
  .studio-tabs::-webkit-scrollbar { display: none; }

  /* Prevent tab buttons from squishing */
  .s-tab-btn {
    flex-shrink: 0;
    min-width: max-content;
    font-size: 0.72rem;
    padding: 8px 12px;
  }

  /* Mission card — tighter padding on phones */
  .s-mission-card {
    padding: clamp(14px, 3vw, 20px);
  }

  /* Studio stats: 3-col always, shrink numbers */
  .studio-stats-row {
    gap: 8px;
  }
  .studio-stat-card {
    padding: 12px 6px;
  }

  /* Portfolio grid: 2-col on phones */
  .studio-portfolio-grid {
    grid-template-columns: repeat(auto-fill, minmax(min(150px, 100%), 1fr));
  }

  /* Action row buttons stack vertically */
  .s-action-row {
    flex-direction: column;
  }
  .s-skip-btn {
    justify-content: center;
  }

  /* Quick tasks grid: single column on phones */
  .quick-grid {
    grid-template-columns: 1fr;
  }
}

/* Extra small phones (< 380px) */
@media (max-width: 380px) {
  .studio-stats-row {
    grid-template-columns: repeat(3, 1fr);
    gap: 6px;
  }
  .studio-stat-card {
    padding: 10px 4px;
  }
  .studio-stat-num {
    font-size: 1.2rem;
  }
  .studio-portfolio-grid {
    grid-template-columns: 1fr;
  }
  .s-type-row {
    gap: 5px;
  }
  .s-type-chip, .s-diff-badge, .s-cat-badge {
    font-size: 0.62rem;
    padding: 2px 7px;
  }
}

/* Cloud Sync Status Indicator */
#cloud-sync-indicator {
  font-family: 'Outfit', sans-serif;
}

