:root{
  --rose:#f7e8e8;--lilac:#ede8f5;--sage:#e6f2ee;--peach:#fdeee6;
  --mauve:#c9a8c9;--mauve-d:#a87ba8;--mauve-light:#e8d5e8;
  --ink:#2e2530;--ink2:#4a3f4d;--mist:#9a8896;--mist2:#b8a8bc;
  --white:#fdfcfc;--card:rgba(255,255,255,0.94);
  --bdr:rgba(201,168,201,0.22);--bdr2:rgba(201,168,201,0.4);
  --shadow:0 8px 40px rgba(160,120,160,0.12);
  --shadow-lg:0 20px 60px rgba(160,120,160,0.18);
  --r-sm:14px;--r-md:20px;--r-lg:28px;--r-xl:36px;
  --grad-bg:radial-gradient(ellipse 70% 55% at 5% 5%,#fdeee688,transparent 50%),radial-gradient(ellipse 55% 45% at 95% 95%,#ede8f588,transparent 50%),#fdfcfc;
  --safe-bottom:env(safe-area-inset-bottom,0px);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;color:var(--ink);min-height:100vh;background:var(--grad-bg);-webkit-tap-highlight-color:transparent;-webkit-text-size-adjust:100%;}
.page{display:none;min-height:100vh;}.page.active{display:flex;}
#landPage.active{flex-direction:column;}
#authPage.active{align-items:center;justify-content:center;min-height:100vh;padding:1.5rem;}
#appPage.active{flex-direction:column;}
.btn{border:none;border-radius:50px;cursor:pointer;font-family:'DM Sans',sans-serif;font-weight:500;letter-spacing:.03em;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:.4rem;white-space:nowrap;-webkit-tap-highlight-color:transparent;touch-action:manipulation;}
.btn-p{background:linear-gradient(135deg,#d4a8d4 0%,#b888b8 100%);color:#fff;padding:.7rem 1.6rem;font-size:.82rem;box-shadow:0 4px 20px rgba(184,136,184,.32);}
.btn-p:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 28px rgba(184,136,184,.46);}
.btn-p:active:not(:disabled){transform:translateY(0);}
.btn-p:disabled{opacity:.55;cursor:not-allowed;}
.btn-g{background:rgba(255,255,255,.82);border:1px solid var(--bdr2);color:var(--ink2);padding:.7rem 1.6rem;font-size:.82rem;}
.btn-g:hover{background:#fff;border-color:var(--mauve);color:var(--ink);}
.btn-sm{padding:.44rem 1rem;font-size:.78rem;min-height:34px;}
.btn-xs{padding:.32rem .75rem;font-size:.73rem;min-height:30px;}
.btn-ic{padding:.44rem .6rem;border-radius:12px;min-height:34px;}
.btn-w{width:100%;}.btn-wide{padding:.7rem 2.2rem;}
.btn-danger{background:rgba(220,80,80,.1);border:1px solid rgba(220,80,80,.2);color:#c06868;padding:.44rem 1rem;font-size:.76rem;}
.btn-danger:hover{background:rgba(220,80,80,.18);}
.inp{width:100%;padding:.88rem 1.2rem;border:1px solid var(--bdr2);border-radius:var(--r-md);font-family:'DM Sans',sans-serif;font-size:.9rem;background:rgba(255,255,255,.9);color:var(--ink);transition:all .18s;outline:none;-webkit-appearance:none;}
.inp:focus{border-color:var(--mauve);box-shadow:0 0 0 3px rgba(201,168,201,.16);}
textarea.inp{resize:vertical;min-height:96px;line-height:1.7;}
select.inp{appearance:none;-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239a8896' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem;}
.lbl{display:block;font-size:.72rem;font-weight:500;color:var(--mist);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.5rem;}
.pw-wrap{position:relative;display:flex;align-items:center;}
.pw-wrap .inp{padding-right:3rem;}
.pw-eye{position:absolute;right:.9rem;cursor:pointer;font-size:1rem;color:var(--mist);user-select:none;transition:color .15s;padding:.5rem;}
.pw-eye:hover{color:var(--mauve);}
.card{background:var(--card);backdrop-filter:blur(14px);border:1px solid var(--bdr);border-radius:var(--r-lg);padding:1.8rem;box-shadow:var(--shadow);}
#toast{position:fixed;bottom:calc(2rem + var(--safe-bottom));left:50%;transform:translateX(-50%) translateY(6px);padding:.75rem 1.5rem;border-radius:50px;font-size:.84rem;z-index:99999;opacity:0;transition:opacity .28s,transform .28s;pointer-events:none;white-space:nowrap;background:var(--ink);color:#fff;box-shadow:0 8px 28px rgba(0,0,0,.2);max-width:88vw;text-align:center;}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
#toast.ok{background:linear-gradient(135deg,#7dbfa4,#5a9e84);}
#toast.err{background:linear-gradient(135deg,#d48a8a,#c06868);}
.spin{width:16px;height:16px;border-radius:50%;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;animation:sp .65s linear infinite;display:inline-block;vertical-align:middle;}
.bigspin{width:44px;height:44px;border-radius:50%;border:3px solid rgba(201,168,201,.18);border-top-color:var(--mauve);animation:sp .75s linear infinite;margin:0 auto;}
@keyframes sp{to{transform:rotate(360deg);}}
.loadbox{text-align:center;padding:3.5rem 2rem;border:1px solid var(--bdr);border-radius:var(--r-lg);background:rgba(253,252,252,.9);}
.loadbox p{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-style:italic;color:var(--mist);margin-top:1rem;}
@keyframes fadeUp{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:translateY(0);}}
@keyframes orb{0%,100%{transform:translateY(0) scale(1);}50%{transform:translateY(-22px) scale(1.06);}}
@keyframes chip{0%,100%{transform:translateY(0);opacity:.65;}50%{transform:translateY(-12px);opacity:1;}}
.anim{animation:fadeUp .45s ease both;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.4;}}
@keyframes rec-pulse{0%,100%{box-shadow:0 0 0 0 rgba(220,80,80,.4);}50%{box-shadow:0 0 0 8px rgba(220,80,80,0);}}
@keyframes slideUp{from{transform:translateY(100%);opacity:0;}to{transform:translateY(0);opacity:1;}}

/* THIN INLINE SLIDERS */
.slider-thin{flex:1;-webkit-appearance:none;height:3px;border-radius:3px;outline:none;cursor:pointer;min-height:20px;background:linear-gradient(90deg,var(--mauve) 50%,rgba(201,168,201,.2) 50%);}
.slider-thin::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid var(--mauve-d);cursor:pointer;box-shadow:0 2px 8px rgba(168,123,168,.35);}
.slider-thin::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid var(--mauve-d);cursor:pointer;}
.srow{display:flex;align-items:center;gap:.75rem;margin-top:.75rem;}
.srow label{font-size:.68rem;font-weight:500;color:var(--mist);letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;min-width:44px;}
.sval{font-family:'Cormorant Garamond',serif;font-size:1rem;font-weight:300;min-width:38px;text-align:right;color:var(--mauve-d);}

/* LANDING */
.land-nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:1.1rem 3.5rem;background:rgba(253,252,252,.92);backdrop-filter:blur(18px);border-bottom:1px solid var(--bdr);}
.logo{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:300;letter-spacing:.03em;cursor:pointer;user-select:none;}
.logo em{color:var(--mauve);font-style:italic;}
.nav-links{display:flex;gap:2rem;align-items:center;}
.nav-links a{text-decoration:none;font-size:.84rem;color:var(--mist);transition:color .18s;}
.nav-links a:hover{color:var(--ink);}
.land-nav-right{display:flex;gap:.6rem;align-items:center;}
.hero{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:9rem 2rem 5rem;position:relative;overflow:hidden;}
.orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.35;pointer-events:none;animation:orb 11s ease-in-out infinite;}
.orb1{width:420px;height:420px;background:#fdd5d5;top:0%;left:-2%;}
.orb2{width:300px;height:300px;background:#d5cdf0;bottom:5%;right:0%;animation-delay:3s;}
.orb3{width:240px;height:240px;background:#bce4d5;top:25%;right:10%;animation-delay:1.5s;}
.chip{position:absolute;background:rgba(255,255,255,.88);backdrop-filter:blur(10px);border:1px solid var(--bdr2);border-radius:50px;padding:.5rem 1.2rem;font-family:'Cormorant Garamond',serif;font-size:.86rem;font-style:italic;color:var(--mist);animation:chip 7s ease-in-out infinite;pointer-events:none;}
.chip:nth-child(1){top:20%;left:2%;}.chip:nth-child(2){top:68%;left:4%;animation-delay:2s;}.chip:nth-child(3){top:16%;right:2%;animation-delay:1s;}.chip:nth-child(4){top:72%;right:3%;animation-delay:3.2s;}
.hero-badge{display:inline-block;border-radius:50px;background:linear-gradient(135deg,var(--rose),var(--lilac));border:1px solid rgba(201,168,201,.3);padding:.4rem 1.4rem;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mauve);font-weight:500;margin-bottom:1.8rem;position:relative;z-index:1;animation:fadeUp .7s ease both;}
.hero h1{font-family:'Cormorant Garamond',serif;font-size:clamp(3.2rem,8.5vw,7rem);font-weight:300;line-height:1.06;position:relative;z-index:1;animation:fadeUp .7s .1s ease both;}
.hero h1 em{font-style:italic;color:var(--mauve);}
.hero-sub{margin-top:1.4rem;max-width:460px;font-size:1.02rem;font-weight:300;color:var(--mist);line-height:1.82;position:relative;z-index:1;animation:fadeUp .7s .2s ease both;}
.hero-cta{margin-top:2.8rem;display:flex;gap:.9rem;flex-wrap:wrap;justify-content:center;position:relative;z-index:1;animation:fadeUp .7s .3s ease both;}
.how{padding:6rem 2rem;background:linear-gradient(160deg,var(--white),#f8f2fc 50%,#f2f8fc);}
.sec{max-width:960px;margin:0 auto;}
.sec-hd{text-align:center;margin-bottom:3.5rem;}
.sec-tag{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--mauve);font-weight:500;margin-bottom:.7rem;display:block;}
.sec-ttl{font-family:'Cormorant Garamond',serif;font-size:clamp(1.9rem,4.5vw,3rem);font-weight:300;line-height:1.15;}
.sec-ttl em{font-style:italic;color:var(--mauve);}
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.3rem;}
.step{background:rgba(255,255,255,.8);border:1px solid var(--bdr);border-radius:var(--r-lg);padding:2rem 1.6rem;text-align:center;transition:transform .28s,box-shadow .28s;}
.step:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);}
.sn{font-family:'Cormorant Garamond',serif;font-size:3rem;font-weight:300;color:rgba(201,168,201,.25);line-height:1;}
.si{font-size:1.9rem;margin:.5rem 0;}
.step h3{font-family:'Cormorant Garamond',serif;font-size:1.32rem;font-weight:400;margin-bottom:.45rem;}
.step p{font-size:.84rem;color:var(--mist);line-height:1.7;font-weight:300;}
.feats{padding:4rem 2rem 6rem;}
.fg{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.3rem;}
.fc{border-radius:var(--r-lg);padding:2rem;border:1px solid var(--bdr);transition:transform .28s,box-shadow .28s;}
.fc:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.fc.c1{background:linear-gradient(135deg,#fdf2f2,#fdeee6);}
.fc.c2{background:linear-gradient(135deg,#f5f0fc,#ede8f5);}
.fc.c3{background:linear-gradient(135deg,#eef8f4,#e6f2ee);}
.fc.c4{background:linear-gradient(135deg,#fef6f0,#fdeee6);}
.fc.c5{background:linear-gradient(135deg,#fdf0f4,#f7e8e8);}
.fc.c6{background:linear-gradient(135deg,#eef2fc,#e8eef8);}
.fc span{font-size:1.9rem;margin-bottom:.8rem;display:block;}
.fc h3{font-family:'Cormorant Garamond',serif;font-size:1.38rem;font-weight:400;margin-bottom:.4rem;}
.fc p{font-size:.84rem;color:var(--mist);line-height:1.72;font-weight:300;}
.guide-section{padding:5rem 2rem;background:linear-gradient(160deg,#f9f5ff,#fff5f8 50%,#f5fff9);}
.guide-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(255px,1fr));gap:1.1rem;max-width:980px;margin:2rem auto 0;}
.guide-card{background:rgba(255,255,255,.88);border:1px solid var(--bdr);border-radius:var(--r-md);padding:1.5rem 1.7rem;transition:transform .25s,box-shadow .25s;}
.guide-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(180,140,180,.12);}
.guide-ic{font-size:1.7rem;margin-bottom:.7rem;}
.guide-card h3{font-family:'Cormorant Garamond',serif;font-size:1.18rem;font-weight:400;margin-bottom:.4rem;}
.guide-card p{font-size:.82rem;color:var(--mist);line-height:1.68;font-weight:300;}
.foot{padding:2rem 3.5rem;border-top:1px solid var(--bdr);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;}
.foot p{font-size:.78rem;color:var(--mist);}

/* AUTH */
.auth-box{width:100%;max-width:420px;}
.auth-logo{text-align:center;margin-bottom:2rem;}
.auth-logo h2{font-family:'Cormorant Garamond',serif;font-size:2.6rem;font-weight:300;}
.auth-logo h2 em{color:var(--mauve);font-style:italic;}
.auth-logo p{color:var(--mist);font-size:.86rem;margin-top:.3rem;}
.tabs{display:flex;background:rgba(201,168,201,.1);border-radius:50px;padding:4px;margin-bottom:1.5rem;}
.tab{flex:1;padding:.65rem;text-align:center;border-radius:50px;cursor:pointer;font-size:.84rem;font-weight:500;color:var(--mist);transition:all .2s;touch-action:manipulation;}
.tab.on{background:#fff;color:var(--ink);box-shadow:0 2px 10px rgba(0,0,0,.07);}
.form{display:flex;flex-direction:column;gap:.85rem;}
.ebox{display:none;color:#c06868;font-size:.82rem;background:#fdf0f0;border:1px solid rgba(192,104,104,.15);border-radius:var(--r-sm);padding:.6rem 1rem;}
.ebox.show{display:block;}
.alink{text-align:center;margin-top:.4rem;font-size:.8rem;color:var(--mist);}
.alink span{color:var(--mauve);cursor:pointer;font-weight:500;}

/* APP NAV */
.app-nav{position:sticky;top:0;z-index:150;display:flex;align-items:center;gap:.6rem;padding:.6rem 1.4rem;flex-wrap:nowrap;background:rgba(253,252,252,.98);backdrop-filter:blur(20px);border-bottom:1px solid var(--bdr);min-height:54px;padding-top:max(.6rem,env(safe-area-inset-top,.6rem));}
.nav-left{display:flex;align-items:center;gap:.4rem;flex-shrink:0;}
.nav-logo{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:300;cursor:pointer;user-select:none;flex-shrink:0;min-width:0;}
.nav-logo em{color:var(--mauve);font-style:italic;}
.nav-home-btn{width:30px;height:30px;border-radius:50%;border:1px solid var(--bdr2);background:rgba(255,255,255,.8);cursor:pointer;font-size:.85rem;display:flex;align-items:center;justify-content:center;transition:all .18s;color:var(--mist);flex-shrink:0;}
.nav-home-btn:hover{background:var(--lilac);color:var(--ink);}
.nav-row1-spacer{flex:1;}
.nav-row2{flex:1;overflow:hidden;display:flex;align-items:center;}
.ntabs-group-row{display:flex;gap:.32rem;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding:0 6px;}
.ntabs-group-row::-webkit-scrollbar{display:none;}
.ntabs-wrap{flex:1;position:relative;overflow:hidden;display:flex;align-items:center;}
.ntabs{display:flex;gap:.35rem;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding:0 8px;}
.ntabs::-webkit-scrollbar{display:none;}
.ntab{padding:.38rem .95rem;border-radius:50px;cursor:pointer;font-size:.74rem;font-weight:500;color:var(--mauve-d);transition:all .22s ease;border:1.5px solid rgba(201,168,201,.5);background:transparent;font-family:'DM Sans',sans-serif;white-space:nowrap;flex-shrink:0;touch-action:manipulation;min-height:32px;}
.ntab.on{background:linear-gradient(135deg,#d4a8d4,#b888b8);color:#fff;border-color:transparent;box-shadow:0 3px 12px rgba(184,136,184,.35);}
.ntab:hover:not(.on){background:rgba(201,168,201,.12);border-color:var(--mauve);}
.ntabs-wrap::before,.ntabs-wrap::after{content:'';position:absolute;top:0;bottom:0;width:20px;z-index:2;pointer-events:none;}
.ntabs-wrap::before{left:0;background:linear-gradient(90deg,rgba(253,252,252,.98),transparent);}
.ntabs-wrap::after{right:0;background:linear-gradient(270deg,rgba(253,252,252,.98),transparent);}
.nav-right{display:flex;align-items:center;gap:.4rem;flex-shrink:0;}
.nav-username{font-family:'Cormorant Garamond',serif;font-size:.95rem;font-style:italic;color:var(--mauve-d);white-space:nowrap;max-width:80px;overflow:hidden;text-overflow:ellipsis;}
.nav-signout{width:30px;height:30px;border-radius:50%;border:1px solid var(--bdr2);background:rgba(255,255,255,.8);cursor:pointer;font-size:.8rem;display:flex;align-items:center;justify-content:center;transition:all .18s;color:var(--mist);flex-shrink:0;}
.nav-signout:hover{background:#fdf0f0;color:#c06868;}

/* Identity panel */
.identity-area-block{background:#fff;border:1px solid var(--bdr);border-radius:var(--r-md);padding:1rem;margin-bottom:.75rem;}
.identity-area-title{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--mauve);margin-bottom:.5rem;}
.identity-stmt{display:flex;align-items:flex-start;gap:.5rem;padding:.35rem 0;border-bottom:1px solid var(--bdr);}
.identity-stmt:last-child{border-bottom:none;}

/* Discover feed */
.discover-card{background:#fff;border:1px solid var(--bdr);border-radius:var(--r-lg);overflow:hidden;box-shadow:0 2px 16px rgba(160,120,160,.07);}
.discover-card-img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;}
.discover-card-body{padding:1rem 1.1rem 1.1rem;}
.discover-card-author{display:flex;align-items:center;gap:.5rem;margin-bottom:.6rem;}
.discover-card-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#d4a8d4,#b888b8);display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#fff;font-weight:600;flex-shrink:0;}
.discover-card-name{font-size:.75rem;font-weight:500;color:var(--ink);}
.discover-card-time{font-size:.65rem;color:var(--mist);}
.discover-card-text{font-size:.88rem;color:var(--ink);line-height:1.75;white-space:pre-wrap;}
.discover-card-tag{display:inline-block;background:var(--lilac);color:var(--mauve);border-radius:50px;padding:.15rem .55rem;font-size:.66rem;font-weight:500;margin-top:.5rem;}

/* Scroll indicator dots */
.tab-scroll-dots{display:flex;justify-content:center;gap:4px;padding:.25rem 0 .1rem;background:rgba(253,252,252,.98);}
.tab-scroll-dot{width:5px;height:5px;border-radius:50%;background:rgba(201,168,201,.25);transition:all .3s;}
.tab-scroll-dot.active{background:var(--mauve);transform:scale(1.3);}

/* HINT BANNER */
.scroll-hint-banner{display:none;position:sticky;top:54px;z-index:140;background:linear-gradient(135deg,rgba(237,232,245,.97),rgba(247,232,232,.97));border-bottom:1px solid var(--bdr);padding:.32rem 1rem;text-align:center;font-size:.72rem;color:var(--mauve);font-family:'Cormorant Garamond',serif;font-style:italic;pointer-events:none;}
.scroll-hint-banner.show{display:block;}

/* WELCOME BANNER (bottom, temporary) */
.welcome-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:9900;
  background:linear-gradient(135deg,rgba(237,232,245,.98),rgba(253,240,248,.98));
  backdrop-filter:blur(18px);
  border-top:1px solid var(--bdr2);
  padding:.9rem 1.4rem calc(.9rem + var(--safe-bottom));
  display:flex;align-items:center;gap:.9rem;
  box-shadow:0 -6px 32px rgba(180,140,180,.18);
  animation:slideUp .4s ease both;
}
.welcome-banner.hidden{display:none;}
.welcome-banner-txt{flex:1;}
.welcome-banner-title{font-family:'Cormorant Garamond',serif;font-size:1rem;font-weight:400;color:var(--ink);}
.welcome-banner-sub{font-size:.72rem;color:var(--mist);margin-top:.15rem;line-height:1.5;}
.welcome-banner-close{width:28px;height:28px;border-radius:50%;border:none;background:rgba(201,168,201,.2);cursor:pointer;font-size:.85rem;color:var(--mist);flex-shrink:0;display:flex;align-items:center;justify-content:center;}

.app-body{flex:1;padding:1.5rem;max-width:880px;margin:0 auto;width:100%;padding-bottom:calc(5rem + var(--safe-bottom));}
.panel{display:none;}.panel.on{display:block;}
.ph{margin-bottom:1.8rem;}
.ph h2{font-family:'Cormorant Garamond',serif;font-size:2.3rem;font-weight:300;line-height:1.15;}
.ph h2 em{font-style:italic;color:var(--mauve);}
.ph p{color:var(--mist);font-size:.86rem;margin-top:.3rem;}

/* MODE CARDS */
.mcards{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.3rem;}
.mc{cursor:pointer;border-radius:var(--r-md);padding:1.1rem 1.2rem;border:2px solid var(--bdr2);background:rgba(255,255,255,.75);transition:all .2s;touch-action:manipulation;text-align:center;}
.mc.on{border-color:var(--mauve);background:linear-gradient(135deg,#fdf2f8,#f4eef8);}
.mc:hover:not(.on){border-color:rgba(201,168,201,.6);}
.mc-ic{font-size:1.3rem;margin-bottom:.3rem;}
.mc-t{font-family:'Cormorant Garamond',serif;font-size:1.05rem;font-weight:400;margin-bottom:.1rem;}
.mc-d{font-size:.75rem;color:var(--mist);}

/* CONTINUE BANNER */
.continue-banner{background:linear-gradient(135deg,#f5f0fc,#fdf2f8);border:1px solid var(--bdr2);border-radius:var(--r-md);padding:.75rem 1rem;margin-bottom:.9rem;display:flex;align-items:center;gap:.7rem;cursor:pointer;transition:all .2s;}
.continue-banner:hover{border-color:var(--mauve);}
.continue-banner.hidden{display:none!important;}
.continue-banner-ic{font-size:1.1rem;flex-shrink:0;}
.continue-banner-txt{flex:1;}
.continue-banner-title{font-family:'Cormorant Garamond',serif;font-size:.95rem;font-weight:400;}
.continue-banner-sub{font-size:.72rem;color:var(--mist);margin-top:.1rem;}
.continue-banner-btns{display:flex;gap:.35rem;flex-shrink:0;}

/* QUICK PANEL */
.quick-panel-btns{display:flex;gap:.5rem;margin-bottom:.9rem;}
.quick-panel-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem .9rem;border-radius:var(--r-md);border:1.5px solid rgba(201,168,201,.45);background:transparent;cursor:pointer;transition:all .2s;font-size:.78rem;font-weight:500;color:var(--mauve-d);font-family:'DM Sans',sans-serif;}
.quick-panel-btn:hover,.quick-panel-btn.active{background:linear-gradient(135deg,#d4a8d4,#b888b8);color:#fff;border-color:transparent;box-shadow:0 3px 12px rgba(184,136,184,.3);}
.quick-panel-drop{display:none;background:rgba(255,255,255,.94);border:1px solid var(--bdr);border-radius:var(--r-md);padding:.85rem;margin-bottom:.9rem;backdrop-filter:blur(14px);}
.quick-panel-drop.open{display:block;}

/* REPEAT ROW */
.rrow{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;margin-top:1.1rem;}
.rbtn{width:34px;height:34px;border-radius:50%;border:1px solid var(--bdr2);background:#fff;cursor:pointer;font-size:1.1rem;color:var(--mauve);display:flex;align-items:center;justify-content:center;transition:all .18s;touch-action:manipulation;flex-shrink:0;}
.rbtn:hover{background:var(--lilac);}
.rval-inp{width:68px;text-align:center;border:1px solid var(--bdr2);border-radius:var(--r-sm);padding:.32rem .5rem;font-family:'Cormorant Garamond',serif;font-size:1.35rem;font-weight:300;color:var(--ink);background:#fff;outline:none;}
.presets{display:flex;gap:.28rem;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;}
.presets::-webkit-scrollbar{display:none;}
.presets .btn{flex-shrink:0;}

/* INTENTION */
.intention-wrap{background:linear-gradient(135deg,rgba(253,240,248,.6),rgba(244,238,248,.6));border:1px solid var(--bdr);border-radius:var(--r-md);padding:.85rem 1rem;margin-bottom:.9rem;}
.intention-label{font-size:.68rem;font-weight:500;color:var(--mauve);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.4rem;}
.intention-inp{width:100%;border:none;background:transparent;font-family:'Cormorant Garamond',serif;font-size:1rem;font-style:italic;color:var(--ink);outline:none;font-weight:300;}
.intention-inp::placeholder{color:var(--mist2);}

/* RTG — collapsed toggle */
.rtg-section{margin-top:1.1rem;}
.rtg-toggle{display:flex;align-items:center;justify-content:space-between;padding:.8rem 1.1rem;background:transparent;border:1.5px solid rgba(201,168,201,.45);border-radius:var(--r-md);cursor:pointer;user-select:none;transition:all .22s;}
.rtg-toggle:hover{background:rgba(201,168,201,.08);border-color:var(--mauve);}
.rtg-toggle-left{display:flex;align-items:center;gap:.55rem;}
.rtg-toggle-ic{font-size:1.1rem;}
.rtg-toggle-txt{font-family:'Cormorant Garamond',serif;font-size:1rem;font-weight:400;color:var(--mauve-d);}
.rtg-toggle-sub{font-size:.68rem;color:var(--mist);margin-top:.05rem;}
.rtg-chevron{font-size:.8rem;color:var(--mist);transition:transform .28s;}
.rtg-chevron.open{transform:rotate(180deg);}
.rtg-body{display:none;opacity:0;transition:opacity .3s ease;}
.rtg-body.open{display:block!important;opacity:1;}
.rtg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.5rem;padding-top:.75rem;}
.rtg-card{
  background:transparent;
  border:1.5px solid rgba(201,168,201,.45);
  border-radius:var(--r-md);padding:.75rem .9rem;cursor:pointer;
  transition:all .22s;text-align:center;
}
.rtg-card:hover{border-color:var(--mauve);background:rgba(201,168,201,.08);}
.rtg-card.selected{background:linear-gradient(135deg,#d4a8d4,#b888b8);border-color:transparent;box-shadow:0 4px 16px rgba(184,136,184,.32);}
.rtg-card.selected .rtg-card-name{color:#fff;}
.rtg-card.selected .rtg-card-count{color:rgba(255,255,255,.75);}
.rtg-card-ic{font-size:1.3rem;margin-bottom:.3rem;}
.rtg-card-name{font-family:'Cormorant Garamond',serif;font-size:.9rem;font-weight:400;color:var(--mauve-d);}
.rtg-card-count{font-size:.66rem;color:var(--mist);margin-top:.15rem;}

/* VOICE SECTION */
.voice-section{margin-top:1rem;padding:.85rem 1rem;background:rgba(255,255,255,.6);border-radius:var(--r-md);border:1px solid var(--bdr);}

/* PLAYER */
.player{background:linear-gradient(135deg,#fdf0f8,#f2edf8);border:1px solid var(--bdr2);border-radius:var(--r-xl);padding:1.6rem;text-align:center;margin-top:1.4rem;box-shadow:0 4px 24px rgba(180,130,180,.1);}
.player-display{min-height:90px;display:flex;align-items:center;justify-content:center;padding:.5rem 0;flex-direction:column;gap:.5rem;}
.intention-display{font-size:.75rem;color:var(--mauve);font-style:italic;opacity:.8;}
.ptxt{font-family:'Cormorant Garamond',serif;font-size:1.7rem;font-style:italic;font-weight:300;color:var(--ink);line-height:1.5;transition:opacity .3s ease;}
.pinfo{margin-top:.6rem;font-size:.78rem;color:var(--mist);}
.prog{height:3px;border-radius:3px;background:rgba(201,168,201,.15);margin-top:.9rem;overflow:hidden;}
.progf{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--mauve),var(--mauve-d));transition:width .5s ease;width:0%;}
.screen-off-badge{display:none;align-items:center;gap:.4rem;padding:.38rem 1rem;border-radius:50px;background:rgba(139,195,155,.15);border:1px solid rgba(100,180,120,.25);font-size:.73rem;color:#5a9e6e;margin-top:.65rem;justify-content:center;}
.screen-off-badge.visible{display:inline-flex;}
.screen-off-dot{width:7px;height:7px;border-radius:50%;background:#5a9e6e;animation:pulse 1.4s ease-in-out infinite;}
.player-ctrl{margin-top:.9rem;padding:.8rem .9rem;background:rgba(255,255,255,.55);border-radius:var(--r-md);border:1px solid rgba(201,168,201,.15);}
.player-ctrl-label{font-size:.65rem;color:var(--mist);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.55rem;text-align:left;}
.player-btns{display:flex;gap:.4rem;flex-wrap:wrap;}
.share-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.32rem .75rem;border-radius:50px;font-size:.72rem;background:rgba(255,255,255,.8);border:1px solid var(--bdr2);cursor:pointer;transition:all .18s;color:var(--mist);font-family:'DM Sans',sans-serif;font-weight:500;}
.share-btn:hover{border-color:var(--mauve);color:var(--ink);}
.alist{display:flex;flex-direction:column;gap:.4rem;margin-top:.9rem;}
.ai{background:#fff;border:1px solid var(--bdr);border-radius:var(--r-md);padding:.75rem 1rem;display:flex;align-items:center;gap:.7rem;transition:all .18s;}
.ai.active{background:linear-gradient(135deg,#fdf0f8,#f4eef8);border-color:var(--mauve);}
.ai-t{flex:1;font-family:'Cormorant Garamond',serif;font-size:1rem;font-style:italic;line-height:1.45;}
.mv-recorder{display:none;margin-top:.9rem;padding:.9rem 1rem;background:rgba(255,255,255,.75);border-radius:var(--r-md);border:1px solid var(--bdr2);}
.mv-rec-item{display:flex;align-items:center;gap:.5rem;padding:.55rem .75rem;border-radius:var(--r-sm);border:1px solid var(--bdr);background:rgba(255,255,255,.7);margin-bottom:.35rem;}
.mv-rec-item.has-recording{background:rgba(201,168,201,.08);border-color:rgba(201,168,201,.35);}
.mv-rec-item.recording-now{background:rgba(220,80,80,.06);border-color:rgba(220,80,80,.25);}
.mv-rec-aff{flex:1;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:.88rem;line-height:1.4;}
.recording-active{animation:rec-pulse 1s ease infinite;background:linear-gradient(135deg,#d4a8d4,#b888b8)!important;color:#fff!important;}

/* STORY */
.sout{border-radius:var(--r-xl);padding:2rem;margin-top:1.4rem;background:linear-gradient(135deg,#fdf8ee,#f3eefc);border:1px solid var(--bdr);}
.sout h3{font-family:'Cormorant Garamond',serif;font-size:1.9rem;font-weight:300;margin-bottom:1rem;}
.sbody{font-size:.92rem;line-height:2;color:var(--ink);font-weight:300;white-space:pre-wrap;}
.story-sentence{transition:background .2s,border-radius .2s;}
.story-sentence.speaking{background:rgba(201,168,201,.18);border-radius:6px;padding:0 3px;}

/* DESIRES */
.desire-item{background:#fff;border:1px solid var(--bdr);border-radius:var(--r-md);padding:.9rem 1.1rem;display:flex;align-items:center;gap:.7rem;transition:box-shadow .2s;margin-bottom:.45rem;}
.desire-item:hover{box-shadow:0 4px 18px rgba(180,140,180,.1);}
.desire-item.done{opacity:.65;}

/* VISION BOARD */
#visionGrid{position:relative;min-height:420px;background:linear-gradient(135deg,#fdf8f4,#f5f0fc);border-radius:var(--r-xl);padding:1rem;overflow:hidden;border:1px solid var(--bdr);}
#visionGrid.locked .vis-card{cursor:default!important;}
#visionGrid.locked .vis-del,#visionGrid.locked .vis-resize{display:none!important;}
#visionGrid.locked [contenteditable]{pointer-events:none;}
.vis-card{position:absolute;cursor:grab;user-select:none;border-radius:var(--r-md);overflow:hidden;box-shadow:0 4px 22px rgba(0,0,0,.13),0 0 0 2px rgba(201,168,201,.3);transition:box-shadow .2s;}
.vis-card:active{cursor:grabbing;}
.vis-card.dragging{opacity:.9;box-shadow:0 16px 44px rgba(0,0,0,.22),0 0 0 2px var(--mauve);}
.vis-inner{width:100%;height:100%;display:flex;flex-direction:column;}
.vis-img{width:100%;flex:1;object-fit:cover;display:block;min-height:0;}
.vis-cap{font-family:'Cormorant Garamond',serif;font-size:.85rem;font-style:italic;text-align:center;padding:.35rem .6rem;color:#fff;outline:none;border:none;background:rgba(0,0,0,.32);cursor:text;text-shadow:0 1px 3px rgba(0,0,0,.6);-webkit-user-select:text;user-select:text;}
.vis-del{position:absolute;top:6px;right:6px;background:rgba(255,255,255,.95);border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;font-size:.75rem;display:none;align-items:center;justify-content:center;z-index:10;color:#c06868;touch-action:manipulation;}
.vis-card:hover .vis-del{display:flex;}
@media(hover:none){.vis-card .vis-del{display:flex;}}
.vis-resize{position:absolute;bottom:6px;right:6px;width:18px;height:18px;background:rgba(255,255,255,.85);border-radius:4px;cursor:nwse-resize;display:none;align-items:center;justify-content:center;font-size:.6rem;color:#888;z-index:10;user-select:none;}
.vis-card:hover .vis-resize{display:flex;}
@media(hover:none){.vis-card .vis-resize{display:flex;}}

/* TRACKER */
.sgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.9rem;margin-bottom:1.4rem;}
.sc{border-radius:var(--r-lg);padding:1.5rem 1rem;text-align:center;border:1px solid var(--bdr);}
.sc.s1{background:linear-gradient(135deg,#fdf2f2,#fdeee6);}
.sc.s2{background:linear-gradient(135deg,#f5f0fc,#ede8f5);}
.sc.s3{background:linear-gradient(135deg,#eef8f4,#e6f2ee);}
.sc.s4{background:linear-gradient(135deg,#fef6f0,#fdeee6);}
.sc.s5{background:linear-gradient(135deg,#fdf0f4,#f7e8e8);}
.sc.s6{background:linear-gradient(135deg,#eef2fc,#e8eef8);}
.snum{font-family:'Cormorant Garamond',serif;font-size:2.6rem;font-weight:300;color:var(--mauve);line-height:1;}
.slbl{font-size:.68rem;color:var(--mist);margin-top:.3rem;font-weight:500;}
.hlist{display:flex;flex-direction:column;gap:.75rem;}
.hi{background:#fff;border:1px solid var(--bdr);border-radius:var(--r-lg);padding:1.2rem 1.4rem;display:flex;align-items:flex-start;justify-content:space-between;gap:.9rem;transition:box-shadow .2s;}
.hi:hover{box-shadow:0 5px 20px rgba(180,140,180,.1);}
.hi-d{font-family:'Cormorant Garamond',serif;font-size:1.08rem;font-style:italic;margin-bottom:.25rem;}
.hi-m{font-size:.76rem;color:var(--mist);}
.hbadge{font-size:.7rem;padding:.25rem .8rem;border-radius:50px;background:var(--lilac);color:var(--mauve);font-weight:500;white-space:nowrap;flex-shrink:0;}
.hist-section{margin-bottom:1.5rem;}
.hist-section-title{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:300;margin-bottom:.75rem;padding-bottom:.4rem;border-bottom:1px solid var(--bdr);}
.empty{text-align:center;padding:4rem 1rem;color:var(--mist);}
.empty-ic{font-size:2.8rem;margin-bottom:.8rem;}
.empty p{font-size:.88rem;line-height:1.6;}
.script-item{background:#fff;border:1px solid var(--bdr);border-radius:var(--r-lg);padding:1.2rem 1.4rem;margin-bottom:.6rem;}
.grat-item{background:#fff;border:1px solid var(--bdr);border-radius:var(--r-md);padding:.8rem .95rem;margin-bottom:.4rem;display:flex;align-items:flex-start;gap:.6rem;}
.man-item{background:linear-gradient(135deg,#fdf5ff,#fff5f8);border:1px solid var(--bdr);border-radius:var(--r-lg);padding:1rem 1.2rem;margin-bottom:.6rem;}
.man-log-area{min-height:160px;}

/* COMMUNITY */
.community-post{background:#fff;border:1px solid var(--bdr);border-radius:var(--r-lg);padding:1.1rem 1.3rem;margin-bottom:.65rem;transition:box-shadow .2s;}
.community-post:hover{box-shadow:0 4px 18px rgba(180,140,180,.1);}
.community-post-content{font-family:'Cormorant Garamond',serif;font-size:1.02rem;font-style:italic;line-height:1.65;margin-bottom:.6rem;color:var(--ink);}
.community-post-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.4rem;}
.community-post-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;}
.community-badge{font-size:.68rem;padding:.2rem .6rem;border-radius:50px;background:var(--lilac);color:var(--mauve);}
.community-time{font-size:.68rem;color:var(--mist);}
.community-love-btn{display:flex;align-items:center;gap:.3rem;padding:.3rem .75rem;border-radius:50px;border:1px solid var(--bdr2);background:rgba(255,255,255,.8);cursor:pointer;font-size:.76rem;transition:all .18s;color:var(--mist);}
.community-love-btn:hover,.community-love-btn.loved{border-color:#f7a8c4;background:#fdf0f5;color:#d4789a;}
.community-filters{display:flex;gap:.35rem;flex-wrap:wrap;margin-bottom:1rem;}

/* TECHNIQUES — expanded cards */
.technique-card{background:#fff;border:1px solid var(--bdr);border-radius:var(--r-lg);padding:0;margin-bottom:.65rem;transition:all .25s;overflow:hidden;}
.technique-card:hover{box-shadow:var(--shadow);}
.technique-header{display:flex;align-items:center;gap:.75rem;padding:1.2rem 1.5rem;cursor:pointer;user-select:none;}
.technique-ic{font-size:1.6rem;flex-shrink:0;}
.technique-name{font-family:'Cormorant Garamond',serif;font-size:1.25rem;font-weight:400;flex:1;}
.technique-tag{font-size:.65rem;padding:.2rem .6rem;border-radius:50px;background:var(--lilac);color:var(--mauve);flex-shrink:0;}
.technique-chevron{font-size:.75rem;color:var(--mist);transition:transform .25s;flex-shrink:0;}
.technique-body{padding:0 1.5rem 1.3rem;font-size:.86rem;color:var(--mist);line-height:1.78;font-weight:300;display:none;}
.technique-body.open{display:block;}
.technique-steps{margin-top:.75rem;display:flex;flex-direction:column;gap:.4rem;}
.technique-step{display:flex;gap:.65rem;align-items:flex-start;font-size:.83rem;}
.technique-step-num{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,var(--lilac),var(--rose));color:var(--mauve-d);font-size:.7rem;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.05rem;}
.technique-best{margin-top:.75rem;padding:.6rem .85rem;border-radius:var(--r-sm);background:linear-gradient(135deg,rgba(253,240,248,.6),rgba(244,238,248,.6));border:1px solid var(--bdr);font-size:.78rem;color:var(--mauve-d);}
.technique-coming{opacity:.55;}

/* SHARE OVERLAY */
#shareOverlay{display:none;position:fixed;inset:0;z-index:10000;background:rgba(46,37,48,.65);backdrop-filter:blur(8px);align-items:center;justify-content:center;padding:1.5rem;}
#shareOverlay.open{display:flex;}
.share-modal{background:#fff;border-radius:var(--r-xl);padding:1.8rem;max-width:420px;width:100%;box-shadow:var(--shadow-lg);}
.share-modal-title{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:300;margin-bottom:1rem;text-align:center;}
#shareCanvas{display:block;width:100%;border-radius:var(--r-lg);margin-bottom:1rem;}
.share-modal-btns{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap;}

/* FULLSCREEN */
.fs-overlay{display:none;position:fixed;inset:0;z-index:9000;background:var(--grad-bg);flex-direction:column;align-items:center;justify-content:center;padding:2.5rem 2rem;text-align:center;gap:.9rem;}
.fs-overlay.open{display:flex;}
.fs-close-row{position:absolute;top:calc(1.2rem + env(safe-area-inset-top,0px));right:1.4rem;display:flex;gap:.55rem;align-items:center;}
.fs-txt{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;color:var(--ink);line-height:1.45;max-width:700px;transition:opacity .32s ease;font-size:clamp(1.8rem,5vw,3.5rem);}
.fs-info{font-size:.83rem;color:var(--mist);}
.fs-bar{width:min(360px,78vw);height:3px;border-radius:3px;background:rgba(201,168,201,.16);overflow:hidden;}
.fs-barf{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--mauve),var(--mauve-d));transition:width .5s ease;}
.fs-btns{display:flex;gap:.55rem;flex-wrap:wrap;justify-content:center;margin-top:.5rem;}
.fs-font-row{display:flex;align-items:center;gap:.45rem;}
.fs-font-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--bdr2);background:rgba(255,255,255,.78);cursor:pointer;font-size:.82rem;color:var(--mauve);}

/* ── MEDITATION ── */
.med-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:.85rem;margin-bottom:1.4rem;}
.med-card{border-radius:var(--r-lg);padding:1.4rem 1rem;text-align:center;cursor:pointer;border:1.5px solid var(--bdr);background:rgba(255,255,255,.85);transition:all .22s;}
.med-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);}
.med-card.active{border-color:var(--mauve);background:linear-gradient(135deg,#fdf2f8,#f0eaf8);}
.med-ic{font-size:1.8rem;margin-bottom:.5rem;}
.med-name{font-family:'Cormorant Garamond',serif;font-size:1rem;font-weight:400;margin-bottom:.2rem;}
.med-dur{font-size:.72rem;color:var(--mist);}
.med-player{background:linear-gradient(135deg,#fdf2f8,#f0eaf8);border:1px solid var(--bdr2);border-radius:var(--r-lg);padding:1.5rem;margin-top:1rem;display:none;}
.med-player.open{display:block;}
.med-ptxt{font-family:'Cormorant Garamond',serif;font-size:1.22rem;font-style:italic;font-weight:300;color:var(--ink);line-height:1.9;text-align:center;padding:.5rem 0;min-height:3.5rem;transition:opacity .4s;}
.med-breath{text-align:center;font-size:.8rem;color:var(--mauve);font-weight:500;letter-spacing:.08em;text-transform:uppercase;margin:.5rem 0;min-height:1.4rem;transition:opacity .4s;}
/* ── DAILY / ORACLE ── */
.daily-card{border-radius:var(--r-xl);padding:2rem 1.5rem;text-align:center;margin-bottom:1.2rem;}
.oracle-deck{display:flex;gap:.7rem;flex-wrap:wrap;justify-content:center;margin:1rem 0;}
.oracle-card-face{width:110px;height:165px;border-radius:14px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:2.2rem;border:2px solid var(--bdr2);background:linear-gradient(135deg,#f0eaf8,#fdf2f8);transition:all .25s;box-shadow:0 4px 14px rgba(180,140,180,.12);}
.oracle-card-face:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.oracle-card-face.flipped{background:linear-gradient(135deg,#ede8f5,#fdf5ff);border-color:var(--mauve);}
.oracle-reveal{background:linear-gradient(135deg,#fdf5ff,#fff5f8);border:1px solid var(--bdr2);border-radius:var(--r-lg);padding:1.5rem;margin-top:1rem;display:none;text-align:center;}
.oracle-reveal.open{display:block;}
/* ── PRACTICE ── */
.prac-card{background:#fff;border:1px solid var(--bdr);border-radius:var(--r-lg);padding:0;margin-bottom:.65rem;overflow:hidden;transition:box-shadow .2s;}
.prac-card:hover{box-shadow:var(--shadow);}
.prac-header{display:flex;align-items:center;gap:.75rem;padding:1.1rem 1.4rem;}
.prac-ic{font-size:1.5rem;flex-shrink:0;}
.prac-name{font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-weight:400;flex:1;}
.prac-body{padding:0 1.4rem 1.2rem;display:none;}
.prac-body.open{display:block;}
.prac-step{display:flex;align-items:flex-start;gap:.7rem;padding:.55rem .4rem;border-bottom:1px solid rgba(201,168,201,.1);}
.prac-step:last-child{border-bottom:none;}
.prac-check{width:20px;height:20px;accent-color:var(--mauve);cursor:pointer;flex-shrink:0;margin-top:.1rem;}
.prac-step-txt{font-size:.86rem;color:var(--ink);line-height:1.65;flex:1;}
.prac-step-txt.done{text-decoration:line-through;color:var(--mist);}
.prac-log-item{background:#fff;border:1px solid var(--bdr);border-radius:var(--r-md);padding:.75rem 1rem;margin-bottom:.4rem;display:flex;justify-content:space-between;align-items:center;gap:.5rem;}
/* ── FEEL IT ── */
.feel-topic-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.7rem;margin-bottom:1.2rem;}
.feel-topic{border-radius:var(--r-md);padding:1rem .8rem;text-align:center;cursor:pointer;border:1.5px solid var(--bdr);background:rgba(255,255,255,.85);transition:all .2s;}
.feel-topic:hover{transform:translateY(-2px);box-shadow:var(--shadow);}
.feel-topic.active{border-color:var(--mauve);background:linear-gradient(135deg,#fdf2f8,#f0eaf8);}
.feel-topic-ic{font-size:1.5rem;margin-bottom:.35rem;}
.feel-topic-name{font-family:'Cormorant Garamond',serif;font-size:.95rem;font-weight:400;}
.feel-content{display:none;animation:fadeUp .35s ease both;}
.feel-content.open{display:block;}
.feel-section{background:#fff;border:1px solid var(--bdr);border-radius:var(--r-md);padding:1.2rem 1.4rem;margin-bottom:.75rem;}
.feel-section-title{font-size:.68rem;font-weight:500;color:var(--mauve);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.65rem;}
.feel-body-item{display:flex;gap:.6rem;align-items:flex-start;padding:.4rem 0;font-size:.86rem;color:var(--ink);line-height:1.6;border-bottom:1px solid rgba(201,168,201,.08);}
.feel-body-item:last-child{border-bottom:none;}
.feel-body-ic{font-size:1rem;flex-shrink:0;margin-top:.05rem;}
/* ── LET GO ── */
.letgo-mood-bar{display:flex;gap:.4rem;justify-content:center;flex-wrap:wrap;margin:.75rem 0;}
.letgo-mood-btn{padding:.45rem 1rem;border-radius:50px;border:1.5px solid var(--bdr2);background:rgba(255,255,255,.8);cursor:pointer;font-size:.82rem;transition:all .2s;font-family:'DM Sans',sans-serif;color:var(--ink2);}
.letgo-mood-btn:hover,.letgo-mood-btn.sel{background:linear-gradient(135deg,#d4a8d4,#b888b8);color:#fff;border-color:transparent;box-shadow:0 3px 12px rgba(184,136,184,.3);}
.letgo-log-item{background:#fff;border:1px solid var(--bdr);border-radius:var(--r-md);padding:.8rem 1rem;margin-bottom:.4rem;}
/* ── ROADMAP ── */
.roadmap-desire-card{background:linear-gradient(135deg,#fdf5ff,#fff5f8);border:1.5px solid var(--bdr2);border-radius:var(--r-lg);padding:1.2rem 1.4rem;margin-bottom:1rem;cursor:pointer;transition:all .2s;}
.roadmap-desire-card:hover{border-color:var(--mauve);box-shadow:var(--shadow);}
.roadmap-desire-card.active{border-color:var(--mauve);background:linear-gradient(135deg,#f5eeff,#ffeef5);}
.roadmap-week{background:#fff;border:1px solid var(--bdr);border-radius:var(--r-md);margin-bottom:.65rem;overflow:hidden;}
.roadmap-week-hd{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.1rem;background:linear-gradient(135deg,#f5f0fc,#fdf5ff);cursor:pointer;user-select:none;}
.roadmap-week-title{font-family:'Cormorant Garamond',serif;font-size:1rem;font-weight:400;}
.roadmap-week-body{padding:.5rem 1.1rem 1rem;display:none;}
.roadmap-week-body.open{display:block;}
.roadmap-action{display:flex;align-items:flex-start;gap:.6rem;padding:.45rem .2rem;border-bottom:1px solid rgba(201,168,201,.1);}
.roadmap-action:last-child{border-bottom:none;}
.roadmap-action input[type=checkbox]{width:18px;height:18px;accent-color:var(--mauve);cursor:pointer;flex-shrink:0;margin-top:.15rem;}
/* ── MIND MOVIE ── */
.mm-scene{background:#fff;border:1px solid var(--bdr);border-radius:var(--r-md);padding:1rem;margin-bottom:.65rem;position:relative;}
.mm-scene-num{font-size:.68rem;font-weight:500;color:var(--mauve);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.4rem;}
.mm-scene-img{width:60px;height:60px;object-fit:cover;border-radius:8px;border:2px solid var(--bdr2);flex-shrink:0;}
.mm-movie-card{background:linear-gradient(135deg,#0a0812,#1a0f2e);border-radius:var(--r-lg);padding:1.2rem 1.4rem;margin-bottom:.7rem;cursor:pointer;border:1px solid rgba(201,168,201,.2);transition:all .2s;}
.mm-movie-card:hover{border-color:var(--mauve);box-shadow:0 6px 24px rgba(180,140,180,.2);}
.mm-movie-title{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:300;color:#fff;}
.mm-movie-meta{font-size:.74rem;color:rgba(255,255,255,.45);margin-top:.25rem;}
/* ── MEDITATION PLAYER (YouTube style) ── */
.med-yt-player{background:linear-gradient(135deg,#1a1025,#0f1a25);border-radius:var(--r-xl);padding:1.5rem;margin-top:1rem;display:none;box-shadow:0 20px 60px rgba(0,0,0,.25);}
.med-yt-player.open{display:block;}
.med-yt-header{text-align:center;margin-bottom:1.2rem;}
.med-yt-title{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:300;color:#fff;margin-bottom:.25rem;}
.med-yt-sub{font-size:.72rem;color:rgba(255,255,255,.45);}
.med-yt-waveform{display:flex;align-items:center;justify-content:center;gap:3px;height:40px;margin:.8rem 0;}
.med-yt-bar{width:3px;border-radius:3px;background:linear-gradient(180deg,#d4a8d4,#b888b8);transform-origin:bottom;transition:height .15s ease;}
.med-yt-bar.idle{height:4px;opacity:.3;}
.med-yt-txt{font-family:'Cormorant Garamond',serif;font-size:1rem;font-style:italic;color:rgba(255,255,255,.9);line-height:1.8;text-align:center;min-height:3rem;padding:.5rem 0;transition:opacity .4s;}
.med-yt-breath{text-align:center;font-size:.75rem;font-weight:600;color:#d4a8d4;letter-spacing:.12em;text-transform:uppercase;min-height:1.2rem;margin:.3rem 0;transition:opacity .3s;}
.med-yt-timeline{margin:1rem 0 .4rem;}
.med-yt-scrubber{width:100%;height:4px;-webkit-appearance:none;appearance:none;border-radius:4px;outline:none;cursor:pointer;background:linear-gradient(90deg,#d4a8d4 0%,rgba(255,255,255,.15) 0%);transition:height .1s;}
.med-yt-scrubber::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:#d4a8d4;cursor:pointer;box-shadow:0 0 6px rgba(212,168,212,.5);}
.med-yt-time{display:flex;justify-content:space-between;font-size:.65rem;color:rgba(255,255,255,.4);margin-top:.3rem;}
.med-yt-controls{display:flex;align-items:center;justify-content:center;gap:1rem;margin:1rem 0;}
.med-yt-playbtn{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#d4a8d4,#b888b8);border:none;color:#fff;font-size:1.4rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(184,136,184,.4);transition:all .2s;}
.med-yt-playbtn:hover{transform:scale(1.05);}
.med-yt-speedbtn{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.7);border-radius:50px;padding:.3rem .7rem;font-size:.72rem;cursor:pointer;transition:all .2s;}
.med-yt-speedbtn.active{background:rgba(212,168,212,.25);border-color:#d4a8d4;color:#d4a8d4;}
.med-yt-volrow{display:flex;align-items:center;gap:.6rem;margin-top:.8rem;}
.med-yt-vollbl{font-size:.65rem;color:rgba(255,255,255,.4);min-width:50px;}
.med-yt-volslider{flex:1;height:3px;-webkit-appearance:none;appearance:none;border-radius:3px;outline:none;cursor:pointer;background:linear-gradient(90deg,#d4a8d4 20%,rgba(255,255,255,.15) 20%);}
.med-yt-volslider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:#d4a8d4;cursor:pointer;}
@media(max-width:768px){.land-nav{padding:.8rem 1.2rem;flex-wrap:wrap;gap:.5rem;}.nav-links{display:none;}.land-nav-right{align-items:center;}.land-nav-right>div{flex-direction:row!important;}.hero{padding:7.5rem 1.4rem 4rem;}.hero h1{font-size:clamp(2.8rem,9.5vw,5rem);}.hero-cta{flex-direction:column;align-items:center;}.hero-cta .btn{width:100%;max-width:320px;}.fg,.steps{grid-template-columns:1fr;}.foot{padding:1.5rem 1.2rem;flex-direction:column;text-align:center;}.nav-username{display:none;}}
@media(max-width:640px){.chip{display:none;}.app-nav{padding:.5rem .65rem;}.app-body{padding:.8rem .8rem;}.ph h2{font-size:1.75rem;}.card{padding:1.1rem;}.player{padding:1.1rem;}.ptxt{font-size:1.4rem;}.sgrid{grid-template-columns:repeat(2,1fr);}.rrow{flex-wrap:wrap;}.presets{width:100%;}.hi{flex-direction:column;}.player-btns .btn{font-size:.75rem;padding:.42rem .85rem;}.dictate-only-desktop{display:none!important;}.med-grid{grid-template-columns:repeat(2,1fr);}.feel-topic-grid{grid-template-columns:repeat(2,1fr);}}
@media(min-width:641px){.dictate-only-desktop{display:inline-flex;}}
@media(max-width:400px){.ntab{font-size:.68rem;padding:.35rem .65rem;}.hero h1{font-size:clamp(2rem,11vw,3.2rem);}.app-body{padding:.65rem;}}


/* ── MUSIC BAR — below nav ── */
.music-bar-slot{width:100%;}
#fixedMusicBar{
  display:flex;align-items:center;gap:.55rem;
  padding:.38rem 1.2rem;
  background:rgba(253,250,255,.97);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(201,168,201,.25);
  box-shadow:0 2px 8px rgba(0,0,0,.05);
  flex-wrap:nowrap;
  overflow-x:auto;
  scrollbar-width:none;
}
#fixedMusicBar::-webkit-scrollbar{display:none;}
#fixedMusicBar select{
  border:1px solid rgba(201,168,201,.4);border-radius:50px;
  padding:.2rem .55rem;font-size:.7rem;color:var(--ink);
  background:rgba(255,255,255,.8);font-family:'DM Sans',sans-serif;
  max-width:130px;flex-shrink:0;
}
#fixedMusicBar button{
  background:linear-gradient(135deg,#d4a8d4,#b888b8);color:#fff;
  border:none;border-radius:50px;padding:.28rem .8rem;
  font-size:.7rem;font-weight:600;cursor:pointer;white-space:nowrap;
  font-family:'DM Sans',sans-serif;flex-shrink:0;
}

/* ── PRACTICE TOOLS ── */
.prac-tool-label{
  font-size:.68rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.1em;color:var(--mauve);
  margin:.9rem 0 .25rem;
}
.prac-tool-desc{font-size:.78rem;color:var(--mist);margin-bottom:.5rem;line-height:1.55;}
.prac-tool-body{margin-bottom:.5rem;}
.prac-tool-divider{border:none;border-top:1px solid var(--bdr);margin:1rem 0 .5rem;}

/* ── STORIES STACK ── */
.story-saved-card{
  background:#fff;border:1px solid var(--bdr);border-radius:var(--r-lg);
  padding:1.2rem 1.4rem;margin-bottom:.75rem;
  transition:box-shadow .2s;
}
.story-saved-card:hover{box-shadow:var(--shadow);}
.story-saved-card.pinned{border-color:var(--mauve);background:linear-gradient(135deg,#fdf5ff,#fff5f8);}
.story-saved-title{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:300;margin-bottom:.5rem;}
.story-saved-body{font-size:.86rem;line-height:1.8;color:var(--ink);max-height:120px;overflow:hidden;position:relative;}
.story-saved-body.expanded{max-height:none;}
.story-saved-fade{position:absolute;bottom:0;left:0;right:0;height:40px;background:linear-gradient(transparent,#fff);pointer-events:none;}
.story-saved-card.pinned .story-saved-fade{background:linear-gradient(transparent,#fff5f8);}

/* ── ROADMAP TABLE ── */
.rm-table{width:100%;border-collapse:collapse;font-size:.82rem;margin-top:.75rem;}
.rm-table th{
  font-size:.64rem;font-weight:600;color:var(--mauve);
  text-transform:uppercase;letter-spacing:.08em;
  padding:.5rem .6rem;border-bottom:2px solid var(--bdr2);
  text-align:left;background:rgba(255,255,255,.6);
}
.rm-table td{padding:.55rem .6rem;border-bottom:1px solid var(--bdr);vertical-align:top;}
.rm-table tr:last-child td{border-bottom:none;}
.rm-table tr:hover td{background:rgba(201,168,201,.04);}
.rm-day-badge{
  font-family:'Cormorant Garamond',serif;font-size:1rem;font-weight:300;
  color:var(--mauve);white-space:nowrap;
}
.rm-practice-tag{
  display:inline-block;background:var(--lilac);color:var(--mauve-d);
  border-radius:50px;padding:.15rem .55rem;font-size:.68rem;
  margin:.1rem .15rem .1rem 0;
}
.rm-done-check{width:20px;height:20px;accent-color:var(--mauve);cursor:pointer;}
.rm-week-reflection{
  background:linear-gradient(135deg,#fdf5ff,#fff5f8);
  border:1px solid var(--bdr2);border-radius:var(--r-md);
  padding:.85rem;margin-top:.75rem;margin-bottom:1rem;
}
.rm-week-reflection label{font-size:.68rem;font-weight:600;color:var(--mauve);text-transform:uppercase;letter-spacing:.08em;display:block;margin-bottom:.4rem;}

/* ── AURA STYLE PICKER ── */
.aura-style-btn{transition:all .18s;font-family:'DM Sans',sans-serif;}
.aura-style-btn.active{box-shadow:0 0 0 2px var(--mauve),0 2px 8px rgba(168,123,168,.28)!important;font-weight:500;}
.aura-style-btn:hover{transform:translateY(-1px);}

/* ── GRATITUDE entries (collapse) ── */
.grat-entries{display:block;}
.grat-entries.hidden{display:none;}

/* ═══════════════════════════════════════════════════
   NEW STYLES — Settings, DreamMap, MedTabs, History fixes
═══════════════════════════════════════════════════ */

/* SETTINGS */
.plan-badge{display:inline-block;font-size:.65rem;padding:.25rem .65rem;border-radius:50px;font-weight:500;letter-spacing:.05em;}
.plan-free{background:rgba(201,168,201,.18);color:var(--mauve-d);}
.plan-manifestor{background:linear-gradient(135deg,#f5eef8,#ede8f5);color:#7a5fa8;}
.plan-alchemist{background:linear-gradient(135deg,#fdf5e0,#f5e8c0);color:#8a6020;}
.plan-day_pass{background:linear-gradient(135deg,#e8f5f0,#d8f0e8);color:#2a7a5a;}
.plan-trialing{background:linear-gradient(135deg,#fdf5ff,#ede8f5);color:var(--mauve-d);}

/* HISTORY — cleaner cards */
.hi{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.2rem;background:#fff;border:1px solid var(--bdr);border-radius:var(--r-md);margin-bottom:.6rem;transition:box-shadow .18s;}
.hi:hover{box-shadow:var(--shadow);}
.hi-d{font-family:'Cormorant Garamond',serif;font-size:1.05rem;font-style:italic;line-height:1.4;color:var(--ink);margin-bottom:.2rem;}
.hi-m{font-size:.72rem;color:var(--mist);letter-spacing:.04em;}
.hbadge{font-size:1.2rem;flex-shrink:0;opacity:.7;margin-top:.15rem;}
.hist-section{margin-bottom:1.2rem;}
.hist-section-title{font-size:.68rem;font-weight:500;color:var(--mist);letter-spacing:.12em;text-transform:uppercase;margin-bottom:.6rem;}

/* MEDITATION TABS */
#medGuidedView,.med-personalised-view{animation:fadeUp .3s ease both;}

/* DREAMMAP */
#dreamChat .user-msg,.dream-user{background:linear-gradient(135deg,#d4a8d4,#b888b8);color:#fff;}
#dreamChat .ai-msg,.dream-ai{background:rgba(255,255,255,.95);border:1px solid var(--bdr);}

/* MIND MOVIE — iPad fix */
#mindmoviePanel{width:100%;box-sizing:border-box;}
#mmCinema{display:none;}
#mmCinema.active{display:flex;}
.mm-scene-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;}

/* TRIAL BANNER */
#trialBanner{font-size:.8rem;font-weight:500;padding:.6rem 1rem;text-align:center;position:relative;z-index:100;}

/* COMMUNITY — technique filter */
.community-filters{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1rem;}

/* ROADMAP custom method */
#rmCustomMethod{border-radius:var(--r-md);}

/* OTP boxes focus ring */
#otpBoxes input:focus{border-color:var(--mauve)!important;box-shadow:0 0 0 3px rgba(201,168,201,.18);}

/* VOICE SELECT optgroups */
#voiceSelect optgroup{font-weight:600;font-size:.78rem;}
#voiceSelect option{font-weight:400;}

/* SETTINGS form spacing */
#settingsPanel .card+.card{margin-top:.2rem;}

/* HOROSCOPE */
#horoscopeSection .card{overflow:hidden;}

/* DREAM MAP viz nodes hover */
#dreamMapViz [onclick]{transition:transform .2s,box-shadow .2s;}
#dreamMapViz [onclick]:hover{transform:scale(1.05);box-shadow:0 8px 24px rgba(160,120,160,.2);}

/* ── RESPONSIVE fixes ── */
@media(max-width:768px){
  .mm-scene-grid{grid-template-columns:1fr;}
  #mindmoviePanel .card{padding:1.2rem;}
  .paywall-plans{grid-template-columns:1fr!important;}
}
@media(min-width:768px) and (max-width:1024px){
  /* iPad */
  #mindmoviePanel{padding:1rem;}
  #mmCinema{padding:1.5rem;}
  #mmCinemaTxt{font-size:clamp(1.3rem,3vw,2rem)!important;}
}

/* ── SETTINGS ── */
.settings-section{background:#fff;border:1px solid var(--bdr);border-radius:var(--r-lg);padding:1.2rem 1.4rem;margin-bottom:.75rem;}
.settings-row{display:flex;align-items:center;justify-content:space-between;padding:.55rem 0;border-bottom:1px solid rgba(201,168,201,.1);gap:.5rem;}
.settings-row:last-child{border-bottom:none;}
.voice-pick-btn{font-size:.8rem!important;padding:.42rem .9rem!important;}

/* ── SETTINGS PANEL ── */
.settings-section-title{font-size:.68rem;font-weight:600;color:var(--mauve);letter-spacing:.12em;text-transform:uppercase;margin-bottom:.75rem;}
/* ── GLOBAL: prevent blue link/button text everywhere ── */
a{color:var(--mauve);text-decoration:none;}
a:visited{color:var(--mauve-d);}
button{color:inherit;}

/* ── SLIDERS: full width music-style everywhere ── */
.slider-thin{
  flex:1;width:100%;-webkit-appearance:none;height:4px;border-radius:4px;
  outline:none;cursor:pointer;
  background:linear-gradient(90deg,var(--mauve) 50%,rgba(201,168,201,.2) 50%);
}
.slider-thin::-webkit-slider-thumb{
  -webkit-appearance:none;width:20px;height:20px;border-radius:50%;
  background:#fff;border:2px solid var(--mauve-d);cursor:pointer;
  box-shadow:0 2px 8px rgba(168,123,168,.35);
}
.slider-thin::-moz-range-thumb{
  width:20px;height:20px;border-radius:50%;background:#fff;
  border:2px solid var(--mauve-d);cursor:pointer;
}
.srow{display:flex;align-items:center;gap:.75rem;margin-top:.8rem;}
.srow label{font-size:.68rem;font-weight:500;color:var(--mist);letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;min-width:44px;}
.sval{font-family:'Cormorant Garamond',serif;font-size:.95rem;font-weight:300;min-width:42px;text-align:right;color:var(--mauve-d);}

/* ── NAV sticky on swipe up ── */
.app-nav{
  position:sticky;top:0;z-index:150;
  transition:transform .3s ease;
}
.app-nav.nav-hidden{transform:translateY(-100%);}
.app-nav.nav-visible{transform:translateY(0);}

/* ── SCRIPT TABS ── */
#scriptDailyView,#scriptDreamView,#scriptSavedView{animation:fadeUp .3s ease both;}

/* ── DAILY CARD grid alignment ── */
.daily-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem;margin-bottom:1rem;}
@media(max-width:640px){.daily-cards-grid{grid-template-columns:repeat(2,1fr);}}
.daily-card-share-btn{
  display:inline-flex;align-items:center;gap:.3rem;margin-top:.6rem;
  padding:.32rem .75rem;border-radius:50px;font-size:.72rem;
  background:rgba(255,255,255,.8);border:1px solid var(--bdr2);
  cursor:pointer;color:var(--mist);font-family:'DM Sans',sans-serif;
}
.daily-card-share-btn:hover{border-color:var(--mauve);color:var(--ink);}

/* ── STORIES LIST ── */
#storiesList .story-saved-card{animation:fadeUp .3s ease both;}

/* ── AFFIRMATIONS: My Affirmations section ── */
.my-affs-section{margin-top:1.5rem;}
.my-affs-header{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:300;margin-bottom:.75rem;}