:root{
  --bg:#07050a;
  --bg2:#0d0812;
  --panel:rgba(255,255,255,.065);
  --panel2:rgba(255,255,255,.095);
  --line:rgba(255,255,255,.13);
  --text:#fff8ff;
  --muted:rgba(255,248,255,.64);
  --muted2:rgba(255,248,255,.46);
  --pink:#ff4fd8;
  --pink2:#ff8dea;
  --rose:#f7a1d8;
  --violet:#b46dff;
  --gold:#ffd98b;
  --danger:#ff5470;
  --ok:#7dffcf;
  --shadow:0 24px 70px rgba(0,0,0,.55);
  --radius:24px;
  --radius2:34px;
  --safe-bottom:env(safe-area-inset-bottom,0px);
  --safe-top:env(safe-area-inset-top,0px);
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"SF Pro Display","Segoe UI",sans-serif;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{height:100%;margin:0;background:var(--bg);color:var(--text);overscroll-behavior:contain}
body{
  min-height:100dvh;
  background:
    radial-gradient(circle at 18% 0%,rgba(255,79,216,.22),transparent 34%),
    radial-gradient(circle at 100% 18%,rgba(180,109,255,.18),transparent 30%),
    linear-gradient(180deg,#08050b 0%,#050407 100%);
  overflow-x:hidden;
}
button,input,textarea,select{font:inherit}
button{border:0;color:inherit;cursor:pointer}
.hidden{display:none!important}
.app-shell{min-height:100dvh;position:relative}
.main-app{
  min-height:100dvh;
  padding:calc(18px + var(--safe-top)) 16px calc(104px + var(--safe-bottom));
  max-width:560px;
  margin:0 auto;
}
.main-app::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.6;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:42px 42px;
  mask-image:linear-gradient(to bottom,transparent,#000 14%,#000 75%,transparent);
}
.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:14px;
  position:relative;
  z-index:2;
}
.topbar h1{font-size:26px;line-height:1.03;margin:3px 0 0;letter-spacing:-.04em}
.eyebrow{
  margin:0;
  color:var(--pink2);
  font-size:11px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.muted{color:var(--muted);line-height:1.45}
.icon-btn{
  width:48px;height:48px;border-radius:18px;
  background:linear-gradient(145deg,rgba(255,79,216,.24),rgba(180,109,255,.14));
  border:1px solid rgba(255,255,255,.15);
  box-shadow:0 0 34px rgba(255,79,216,.14), inset 0 1px 0 rgba(255,255,255,.13);
  font-size:26px;
}
.hero-card{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.14);
  background:linear-gradient(145deg,rgba(255,255,255,.09),rgba(255,255,255,.035));
  border-radius:var(--radius2);
  padding:18px;
  box-shadow:var(--shadow),0 0 60px rgba(255,79,216,.09);
  margin-bottom:20px;
}
.hero-bg{
  position:absolute;inset:-1px;
  background:
    radial-gradient(circle at 78% 20%,rgba(255,79,216,.24),transparent 32%),
    radial-gradient(circle at 20% 80%,rgba(180,109,255,.15),transparent 36%);
  filter:blur(.2px);
}
.hero-bg-img{
  position:absolute;inset:-30px;
  background-size:cover;
  background-position:center;
  filter:blur(26px) saturate(1.5);
  opacity:0;
  transition:opacity 1.2s ease;
  transform:scale(1.08);
}
.hero-content{position:relative;display:flex;justify-content:space-between;align-items:center;gap:14px}
.hero-card h2{font-size:54px;margin:4px 0 2px;letter-spacing:-.08em;text-shadow:0 0 26px rgba(255,79,216,.28)}
.streak-badge{
  display:none;
  align-items:center;
  gap:5px;
  margin-top:6px;
  font-size:12px;
  font-weight:800;
  color:var(--gold);
  text-shadow:0 0 12px rgba(255,217,139,.5);
  animation:streakPop .6s cubic-bezier(.2,.85,.2,1.4) both;
}
@keyframes streakPop{from{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}
.global-ring{width:102px;height:102px;position:relative;flex:0 0 auto}
.global-ring svg{width:100%;height:100%;transform:rotate(-90deg);filter:drop-shadow(0 0 14px rgba(255,79,216,.45))}
.ring-bg{fill:none;stroke:rgba(255,255,255,.11);stroke-width:10}
.ring-value{
  fill:none;stroke:url(#fake);
  stroke:var(--pink);
  stroke-linecap:round;stroke-width:10;
  stroke-dasharray:314;stroke-dashoffset:314;
  will-change:stroke-dashoffset;
  transition:stroke-dashoffset 1.8s cubic-bezier(.2,.85,.2,1);
}
.global-ring span{position:absolute;inset:0;display:grid;place-items:center;font-weight:900;font-size:19px}
.neon-line{
  position:relative;z-index:2;margin-top:16px;height:9px;border-radius:999px;
  background:rgba(255,255,255,.08);overflow:hidden;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);
}
.neon-line span{
  display:block;width:0%;height:100%;border-radius:inherit;
  background:linear-gradient(90deg,var(--pink),var(--violet),var(--pink2));
  box-shadow:0 0 22px rgba(255,79,216,.9),0 0 44px rgba(255,79,216,.4);
  will-change:width;
  transition:width 1.6s cubic-bezier(.2,.85,.2,1);
}
.view{display:none;position:relative;z-index:2;animation:fadeIn .4s ease}
.view.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.section-title-row{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin:18px 0 8px}
.section-title-row h2{margin:2px 0 0;font-size:25px;letter-spacing:-.04em}
.hint{margin:0 0 14px;color:var(--muted2);font-size:13px;line-height:1.4}
.mini-btn,.primary-btn,.ghost-btn,.danger-btn{
  min-height:42px;padding:0 15px;border-radius:16px;font-weight:800;
  border:1px solid rgba(255,255,255,.13);
}
.mini-btn,.primary-btn{
  background:linear-gradient(135deg,rgba(255,79,216,.95),rgba(180,109,255,.78));
  box-shadow:0 0 22px rgba(255,79,216,.22),inset 0 1px 0 rgba(255,255,255,.24);
}
.ghost-btn{
  background:rgba(255,255,255,.07);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.danger-btn{
  background:rgba(255,84,112,.12);
  color:#ffdbe2;
  border-color:rgba(255,84,112,.35);
}
.full{width:100%;display:flex;align-items:center;justify-content:center}
.stack{display:grid;gap:10px}
.vision-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  grid-auto-flow:dense;
  gap:12px;
  min-height:180px;
}
.vision-card{
  position:relative;
  min-height:190px;
  border-radius:28px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.13);
  background:rgba(255,255,255,.065);
  box-shadow:0 18px 45px rgba(0,0,0,.34),0 0 0 1px rgba(255,79,216,.03);
  touch-action:none;
  user-select:none;
  -webkit-user-select:none;
  -webkit-touch-callout:none;
  transform:translateZ(0);
  transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease,opacity .3s ease;
}
.vision-card.large{grid-column:span 2;min-height:260px}
.vision-card.tall{min-height:280px}
.vision-card.hero{grid-column:span 2;min-height:350px}
.vision-card.dragging{
  opacity:.88;z-index:50;transform:scale(1.04) rotate(.8deg);
  box-shadow:0 30px 80px rgba(0,0,0,.6),0 0 34px rgba(255,79,216,.24);
  border-color:rgba(255,79,216,.42);
}
.vision-card.drop-target{outline:2px solid rgba(255,79,216,.55);outline-offset:3px}
.vision-img-wrap{position:absolute;inset:0;overflow:hidden;background:linear-gradient(135deg,rgba(255,79,216,.16),rgba(180,109,255,.08))}
.vision-img-wrap img{width:100%;height:100%;object-fit:cover;transform-origin:center;will-change:transform;filter:saturate(1.07) contrast(1.03);transition:transform .4s ease}
.vision-card:active .vision-img-wrap img{transform:scale(1.04)}
.vision-gradient{position:absolute;inset:0;background:linear-gradient(180deg,transparent 20%,rgba(0,0,0,.1) 52%,rgba(0,0,0,.83) 100%)}
.vision-card-body{position:absolute;left:13px;right:13px;bottom:13px;z-index:2}
.pill{
  display:inline-flex;align-items:center;gap:6px;
  min-height:26px;padding:0 10px;border-radius:999px;
  color:rgba(255,255,255,.86);font-size:11px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;
  background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.16);
  -webkit-backdrop-filter:blur(12px);
  backdrop-filter:blur(12px);
}
.vision-card h3{font-size:22px;margin:8px 0 2px;letter-spacing:-.04em;text-shadow:0 2px 20px rgba(0,0,0,.55)}
.vision-card p{margin:0;color:rgba(255,255,255,.72);font-size:13px;line-height:1.35}
.objective-list,.focus-list{display:grid;gap:12px}
.objective-card,.settings-card,.note-card,.focus-card{
  position:relative;
  border-radius:28px;
  background:linear-gradient(145deg,rgba(255,255,255,.085),rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.13);
  box-shadow:0 18px 50px rgba(0,0,0,.27);
  padding:16px;
  overflow:hidden;
  --obj-c:var(--pink);
}
.objective-card::before,.focus-card::before{
  content:"";
  position:absolute;inset:-1px;
  background:radial-gradient(circle at 88% 12%,color-mix(in srgb,var(--obj-c) 15%,transparent),transparent 30%);
  pointer-events:none;
}
.objective-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;position:relative}
.objective-card h3,.settings-card h3,.focus-card h3{margin:0;font-size:19px;letter-spacing:-.03em}
.objective-card p,.settings-card p,.focus-card p{margin:6px 0 0;font-size:13px}
.score-chip{
  flex:0 0 auto;min-width:56px;height:38px;border-radius:14px;
  display:grid;place-items:center;font-weight:950;
  background:color-mix(in srgb,var(--obj-c) 13%,transparent);
  border:1px solid color-mix(in srgb,var(--obj-c) 25%,transparent);
  box-shadow:0 0 22px color-mix(in srgb,var(--obj-c) 8%,transparent);
}
.progress-track{
  height:10px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden;margin-top:14px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.07);
}
.progress-fill{
  width:0%;height:100%;border-radius:inherit;
  background:linear-gradient(90deg,var(--obj-c),var(--pink2));
  box-shadow:0 0 22px color-mix(in srgb,var(--obj-c) 75%,transparent);
  will-change:width;
  transition:width 1.2s cubic-bezier(.2,.85,.2,1);
}
.objective-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.meta-pill{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  color:var(--muted);
  border-radius:999px;
  padding:7px 10px;
  font-size:12px;font-weight:750;
}
.subgoal-block{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.052);
  border-radius:22px;
  padding:12px;
  margin-top:12px;
}
.subgoal-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.subgoal-head h4{margin:0;font-size:15px}
.action-row{
  display:flex;align-items:center;gap:10px;
  min-height:44px;padding:8px 0;
  border-top:1px solid rgba(255,255,255,.08);
  cursor:pointer;
  transition:opacity .2s;
}
.action-row:first-of-type{border-top:0}
.action-row:active{opacity:.7}
.check{
  width:27px;height:27px;border-radius:10px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.06);
  display:grid;place-items:center;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.1);
  flex:0 0 auto;
  transition:background .3s,border-color .3s,box-shadow .3s;
}
.check.done,.action-row.done .check{
  border-color:rgba(255,79,216,.65);
  background:linear-gradient(135deg,var(--pink),var(--violet));
  box-shadow:0 0 18px rgba(255,79,216,.45);
}
.check.done::after,.action-row.done .check::after{content:"✓";font-weight:950}
.action-row.done .action-text{text-decoration:line-through;color:var(--muted2)}
.action-text{flex:1;color:rgba(255,255,255,.86);line-height:1.35}
.inline-delete{
  width:44px;height:44px;border-radius:13px;
  background:rgba(255,84,112,.09);color:#ffcbd4;border:1px solid rgba(255,84,112,.22);
}
.notes-area{
  width:100%;
  min-height:220px;
  resize:vertical;
  border:1px solid rgba(255,255,255,.13);
  background:rgba(255,255,255,.065);
  color:var(--text);
  border-radius:28px;
  padding:16px;
  outline:none;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.notes-area:focus,.field input:focus,.field textarea:focus,.field select:focus{
  border-color:rgba(255,79,216,.52);
  box-shadow:0 0 0 4px rgba(255,79,216,.1);
}
.ritual-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}
.bottom-nav{
  position:fixed;
  left:50%;bottom:10px;transform:translateX(-50%);
  width:min(540px,calc(100% - 20px));
  padding:6px 6px calc(6px + var(--safe-bottom));
  border-radius:26px;
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:2px;
  background:rgba(14,10,18,.78);
  border:1px solid rgba(255,255,255,.13);
  box-shadow:0 20px 60px rgba(0,0,0,.48),0 0 36px rgba(255,79,216,.08);
  -webkit-backdrop-filter:blur(22px);
  backdrop-filter:blur(22px);
  z-index:80;
}
.bottom-nav button{
  min-height:50px;border-radius:17px;background:transparent;color:var(--muted);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  font-size:10.5px;font-weight:850;padding:0 1px;
  transition:color .2s,background .2s;
}
.bottom-nav span{font-size:16px;line-height:1}
.bottom-nav button.active{
  color:#fff;
  background:linear-gradient(145deg,rgba(255,79,216,.2),rgba(255,255,255,.07));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 0 20px rgba(255,79,216,.08);
}
.bottom-nav button[data-tab="Today"].active{
  background:linear-gradient(145deg,rgba(255,217,139,.2),rgba(255,79,216,.1));
  color:var(--gold);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 0 20px rgba(255,217,139,.12);
}
.lock-screen{
  min-height:100dvh;
  display:grid;
  place-items:center;
  padding:28px 16px;
  position:relative;
  overflow:hidden;
}
.orb{position:absolute;border-radius:999px;filter:blur(10px);opacity:.45}
.orb-a{width:280px;height:280px;background:rgba(255,79,216,.34);top:-70px;left:-90px}
.orb-b{width:260px;height:260px;background:rgba(180,109,255,.26);bottom:-90px;right:-90px}
.lock-card{
  width:min(430px,100%);
  border-radius:36px;
  padding:22px;
  background:linear-gradient(145deg,rgba(255,255,255,.1),rgba(255,255,255,.045));
  border:1px solid rgba(255,255,255,.14);
  box-shadow:var(--shadow),0 0 80px rgba(255,79,216,.12);
  -webkit-backdrop-filter:blur(20px);
  backdrop-filter:blur(20px);
}
.brand-lock{display:flex;align-items:center;gap:13px;margin-bottom:18px}
.brand-mark{width:54px;height:54px;display:grid;place-items:center;border-radius:20px;background:#1e0936;border:1px solid rgba(255,79,216,.22);font-size:27px;flex-shrink:0}
.lock-card h1{font-size:28px;letter-spacing:-.05em;margin:2px 0 0}
.field{display:grid;gap:7px;margin:13px 0}
.field span{font-size:12px;color:var(--muted);font-weight:800;letter-spacing:.04em}
.field input,.field textarea,.field select{
  width:100%;
  border:1px solid rgba(255,255,255,.13);
  background:rgba(0,0,0,.24);
  color:var(--text);
  border-radius:18px;
  min-height:48px;
  padding:0 14px;
  outline:none;
}
.field textarea{min-height:100px;padding:14px;resize:vertical}
.feedback{min-height:20px;color:#ffd2e4;font-size:13px}
.sheet-backdrop{
  position:fixed;inset:0;
  background:rgba(0,0,0,.52);
  -webkit-backdrop-filter:blur(6px);
  backdrop-filter:blur(6px);
  z-index:120;
}
.editor-sheet{
  position:fixed;left:50%;bottom:0;transform:translate3d(-50%,0,0);
  width:min(560px,100%);
  max-height:88dvh;
  overflow:auto;
  -webkit-overflow-scrolling:touch;
  padding:10px 16px calc(24px + var(--safe-bottom));
  background:
    radial-gradient(circle at 82% 8%,rgba(255,79,216,.15),transparent 28%),
    linear-gradient(180deg,rgba(20,13,25,.98),rgba(8,6,10,.99));
  border:1px solid rgba(255,255,255,.13);
  border-bottom:0;
  border-radius:34px 34px 0 0;
  box-shadow:0 -24px 70px rgba(0,0,0,.58);
  z-index:130;
  animation:sheetIn .5s cubic-bezier(.2,.85,.2,1);
}
@keyframes sheetIn{from{transform:translate3d(-50%,50px,0);opacity:.4}to{transform:translate3d(-50%,0,0);opacity:1}}
.sheet-handle{
  width:46px;height:5px;border-radius:999px;
  background:rgba(255,255,255,.22);
  margin:2px auto 16px;
  cursor:grab;
  transition:background .2s;
}
.sheet-handle:hover{background:rgba(255,255,255,.38)}
.sheet-handle:active{cursor:grabbing}
.sheet-title-row{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:12px}
.sheet-title-row h2{margin:0;font-size:24px;letter-spacing:-.04em}
.close-btn{width:44px;height:44px;border-radius:15px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12)}
.form-grid{display:grid;gap:10px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.upload-box{
  min-height:138px;border-radius:24px;border:1px dashed rgba(255,255,255,.22);
  background:rgba(255,255,255,.045);
  display:grid;place-items:center;text-align:center;padding:16px;color:var(--muted);
  overflow:hidden;
}
.upload-box img{width:100%;max-height:240px;object-fit:cover;border-radius:19px}
.slider-row{display:grid;grid-template-columns:92px 1fr 44px;gap:10px;align-items:center;margin:10px 0}
input[type="range"]{width:100%;accent-color:var(--pink)}
.segmented{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.segmented button{min-height:42px;border-radius:15px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12)}
.segmented button.active{background:rgba(255,79,216,.18);border-color:rgba(255,79,216,.42);box-shadow:0 0 18px rgba(255,79,216,.1)}
.image-tune{
  border-radius:24px;
  background:rgba(255,255,255,.045);
  border:1px solid rgba(255,255,255,.1);
  padding:12px;
}
.actions-toolbar{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.settings-row{display:flex;align-items:center;justify-content:space-between;gap:16px}
.switch{position:relative;width:58px;height:34px;flex:0 0 auto}
.switch input{display:none}
.switch span{position:absolute;inset:0;border-radius:999px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);transition:.2s}
.switch span::after{content:"";position:absolute;left:4px;top:4px;width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,.82);transition:.2s}
.switch input:checked+span{background:rgba(255,79,216,.32);border-color:rgba(255,79,216,.5);box-shadow:0 0 20px rgba(255,79,216,.18)}
.switch input:checked+span::after{transform:translateX(24px);background:#fff}
.switch input:disabled+span{opacity:.38;cursor:not-allowed}
.toast{
  position:fixed;left:50%;bottom:calc(92px + var(--safe-bottom));transform:translateX(-50%);
  max-width:calc(100% - 34px);
  border-radius:18px;
  padding:12px 18px;
  color:#fff;
  background:rgba(15,10,18,.92);
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 16px 42px rgba(0,0,0,.45),0 0 28px rgba(255,79,216,.18);
  -webkit-backdrop-filter:blur(16px);
  backdrop-filter:blur(16px);
  z-index:210;
  font-size:13px;
  font-weight:600;
  animation:toastIn .35s cubic-bezier(.2,.85,.2,1.3);
}
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(12px) scale(.92)}to{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}}
.confetti-layer{position:fixed;inset:0;pointer-events:none;z-index:220;overflow:hidden}
.spark{
  position:absolute;border-radius:50%;
  background:var(--pink);
  animation:spark 1s ease-out forwards;
}
.spark-square{border-radius:3px!important}
@keyframes spark{
  0%{transform:translate(0,0) scale(1) rotate(0deg);opacity:1}
  100%{transform:translate(var(--dx),var(--dy)) scale(.05) rotate(540deg);opacity:0}
}
.empty-state{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.045);
  border-radius:28px;
  padding:22px;
  text-align:center;
}
.empty-state h3{margin:0 0 6px;font-size:19px}
.empty-state p{margin:0 0 14px;color:var(--muted);line-height:1.4}
.file-btn{position:relative;overflow:hidden}
.small-link{color:var(--pink2);background:none;padding:0;text-decoration:underline;text-underline-offset:4px}

/* Color picker */
.color-picker{display:flex;gap:10px;flex-wrap:wrap;padding:4px 0}
.color-swatch{
  width:32px;height:32px;border-radius:50%;border:3px solid transparent;
  cursor:pointer;transition:transform .25s cubic-bezier(.2,.85,.2,1.4),border-color .2s;
  outline:none;
}
.color-swatch.active{border-color:#fff;transform:scale(1.22);box-shadow:0 0 12px rgba(255,255,255,.3)}

/* Vision full-screen viewer */
.vision-viewer{
  position:fixed;inset:0;z-index:200;background:#000;
  animation:viewerIn .45s cubic-bezier(.2,.85,.2,1);
  touch-action:pan-x;
}
@keyframes viewerIn{from{opacity:0;transform:scale(1.08)}to{opacity:1;transform:none}}
@keyframes viewerOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.94)}}
.vision-viewer-img{
  width:100%;height:100dvh;object-fit:cover;
  transition:transform .35s ease,opacity .25s;
  pointer-events:none;
}
.vision-viewer-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.5) 0%,transparent 28%,transparent 55%,rgba(0,0,0,.8) 100%);
}
.vision-viewer-nav{
  position:absolute;
  top:calc(18px + env(safe-area-inset-top));
  right:16px;
  display:flex;gap:8px;
}
.vision-viewer-btn{
  width:44px;height:44px;border-radius:13px;
  background:rgba(0,0,0,.45);
  border:1px solid rgba(255,255,255,.2);
  color:#fff;font-size:18px;
  -webkit-backdrop-filter:blur(10px);
  backdrop-filter:blur(10px);
}
.vision-viewer-info{
  position:absolute;
  bottom:calc(34px + env(safe-area-inset-bottom));
  left:20px;right:20px;
}
.vision-viewer-info h2{
  color:#fff;font-size:28px;margin:6px 0 6px;
  text-shadow:0 2px 24px rgba(0,0,0,.8);
  letter-spacing:-.04em;
}
.vision-viewer-info p{color:rgba(255,255,255,.72);margin:0}
.vision-viewer-dots{
  position:absolute;
  bottom:calc(210px + env(safe-area-inset-bottom));
  left:50%;transform:translateX(-50%);
  display:flex;gap:6px;
}
.viewer-dot{
  height:5px;border-radius:3px;background:rgba(255,255,255,.35);
  transition:width .35s cubic-bezier(.2,.85,.2,1),background .35s;
  width:5px;
}
.viewer-dot.active{width:20px;background:#fff}
.vision-viewer-swipe-hint{
  position:absolute;top:50%;left:0;right:0;
  display:flex;justify-content:space-between;padding:0 12px;
  transform:translateY(-50%);
  pointer-events:none;
}
.swipe-arrow{
  width:40px;height:40px;border-radius:50%;
  background:rgba(0,0,0,.3);
  display:grid;place-items:center;
  color:rgba(255,255,255,.5);
  font-size:18px;
  -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px);
}

/* Today view */
.today-actions{display:grid;gap:12px;margin:14px 0}
.today-pick{
  border-radius:22px;
  padding:14px 16px;
  background:linear-gradient(145deg,rgba(255,255,255,.085),rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.13);
  display:flex;align-items:center;gap:14px;
  cursor:pointer;
  transition:opacity .3s,transform .2s;
}
.today-pick:active{transform:scale(.98)}
.today-pick.done{opacity:.55}
.today-pick-text{flex:1}
.today-pick-title{font-size:15px;font-weight:800;margin:0 0 3px;color:var(--text)}
.today-pick-obj{font-size:12px;color:var(--muted);margin:0}
.today-progress{margin:0 0 6px}

/* Action prioritaire */
.prio-star{color:var(--gold);font-size:.92em}
.action-row.is-priority .action-text{color:#fff}
.prio-btn{
  width:44px;height:44px;border-radius:12px;flex:0 0 auto;
  background:rgba(255,217,139,.08);border:1px solid rgba(255,217,139,.2);
  color:rgba(255,217,139,.45);font-size:15px;line-height:1;
  transition:color .2s,background .2s,border-color .2s;
}
.prio-btn.on{color:var(--gold);background:rgba(255,217,139,.16);border-color:rgba(255,217,139,.45);box-shadow:0 0 14px rgba(255,217,139,.22)}

/* Bilan de la semaine */
.weekly-card{
  border-radius:28px;
  background:linear-gradient(145deg,rgba(255,217,139,.12),rgba(255,79,216,.05));
  border:1px solid rgba(255,217,139,.22);
  padding:16px 18px;margin-bottom:14px;
  box-shadow:0 0 30px rgba(255,217,139,.06);
}
.weekly-card .big{font-size:30px;font-weight:900;letter-spacing:-.04em;margin:3px 0 4px}
.weekly-card .sub{color:var(--muted);font-size:13px;margin:0;line-height:1.4}

/* Guide d'utilisation (sheet) */
.guide h3{font-size:16px;margin:18px 0 8px;letter-spacing:-.02em}
.guide-intro{color:var(--muted);line-height:1.5;margin:0 0 2px}
.guide-list{margin:0;padding-left:20px;color:var(--muted);line-height:1.65}
.guide-list b,.guide-tab b{color:var(--text)}
.guide-tab{display:flex;gap:12px;align-items:flex-start;padding:10px 0;border-top:1px solid rgba(255,255,255,.07);color:var(--muted);line-height:1.45;font-size:14px}
.guide-tab:first-of-type{border-top:0}
.guide-tab span{font-size:18px;flex:0 0 auto;width:24px;text-align:center;color:var(--pink2)}

@media (min-width:560px){
  .main-app{padding-left:18px;padding-right:18px}
}
button:focus-visible{outline:2px solid var(--pink);outline-offset:2px}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}
