/* Fun-Ture v2 — refined app-style design system */
:root,[data-theme="dark"]{
  --bg-base:#0D0B14; --bg2-base:#17131F;
  /* Rose (default) stays untinted — matches original vibe */
  --bg:var(--bg-base); --bg2:var(--bg2-base);
  --bg3:#1E1828; --bg4:#2A1F35;
  --card:rgba(255,250,245,.04); --card-h:rgba(255,250,245,.07); --card-strong:rgba(255,250,245,.09);
  --border:rgba(255,220,230,.08); --border2:rgba(255,220,230,.14); --border-accent:color-mix(in oklab,var(--rose) 32%,transparent);
  --text:#F1E9E3; --text2:#A89A96; --text3:#6E635F;
  --rose:#E8A5C0; --lavender:#B9A4E3; --apricot:#F2B988; --teal:#8BB8B4; --gold:#E8C87A; --coral:#F09090;
  --ring:0 0 0 1px rgba(255,220,230,.06) inset, 0 1px 0 rgba(255,220,230,.08) inset;
  --sh1:0 1px 2px rgba(0,0,0,.25); --sh2:0 4px 18px rgba(0,0,0,.35),0 1px 3px rgba(0,0,0,.2);
  --sh3:0 12px 40px rgba(0,0,0,.45),0 2px 8px rgba(0,0,0,.25);
  --radius:16px; --radius-sm:12px; --radius-lg:22px;
  --nav-h:76px; --top-h:64px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior-y:contain}
body{font-family:'Inter Tight',-apple-system,sans-serif;background:var(--bg-base);background:var(--bg);color:var(--text);line-height:1.55;min-height:100dvh;letter-spacing:-.005em}
body::before{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(800px 600px at 15% -10%,color-mix(in oklab,var(--rose) 26%,transparent),transparent 65%),radial-gradient(700px 600px at 110% 20%,color-mix(in oklab,var(--lavender) 24%,transparent),transparent 65%),radial-gradient(700px 600px at 50% 110%,color-mix(in oklab,var(--lavender) 18%,transparent),transparent 60%)}
body::after{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.45;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.035 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");mix-blend-mode:overlay}
#root,.ft-screen{position:relative;z-index:1}
.ft-topbar,.ft-nav,.ft-fab{z-index:40}
input,select,button,textarea{font-family:inherit;letter-spacing:inherit;color:inherit}
button{cursor:pointer;background:none;border:none}
::selection{background:color-mix(in oklab,var(--rose) 55%,transparent);color:#fff}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:99px}

[data-theme="light"]{
  --bg-base:#FAF5F0; --bg2-base:#FFFFFF;
  --bg:var(--bg-base); --bg2:var(--bg2-base);
  --bg3:#F3EBE3; --bg4:#EADFD4;
  --card:rgba(90,60,70,.04); --card-h:rgba(90,60,70,.07); --card-strong:rgba(90,60,70,.09);
  --border:rgba(90,60,70,.10); --border2:rgba(90,60,70,.16);
  --text:#2A1F28; --text2:#6B5862; --text3:#9E8C95;
  --rose:#C55F8A; --lavender:#8067C2; --apricot:#D97B3C; --teal:#5A8682; --gold:#B8944A; --coral:#C56868;
  /* --border-accent inherits from :root (color-mix of var(--rose)) so it derives automatically */
}
[data-theme="light"] body::after{opacity:.25}

/* ============ PALETTE OVERRIDES (brand color variations) ============
   Only --rose and --lavender change — everything else (border-accent, body glow,
   hero bg, etc.) derives via color-mix so it all follows automatically. */
/* Non-rose palettes subtly tint the background + card surfaces. Rose keeps the original dark-purple vibe. */
html[data-palette]{
  --bg:color-mix(in oklab,var(--rose) 6%,var(--bg-base));
  --bg2:color-mix(in oklab,var(--lavender) 6%,var(--bg2-base));
  --card:color-mix(in oklab,var(--rose) 4%,rgba(255,250,245,.04));
  --card-h:color-mix(in oklab,var(--rose) 6%,rgba(255,250,245,.07));
  --card-strong:color-mix(in oklab,var(--lavender) 5%,rgba(255,250,245,.09));
}
html[data-theme="light"][data-palette]{
  --bg:color-mix(in oklab,var(--rose) 5%,var(--bg-base));
  --bg2:color-mix(in oklab,var(--lavender) 3%,var(--bg2-base));
  --card:color-mix(in oklab,var(--rose) 3%,rgba(90,60,70,.04));
  --card-h:color-mix(in oklab,var(--rose) 5%,rgba(90,60,70,.07));
  --card-strong:color-mix(in oklab,var(--lavender) 4%,rgba(90,60,70,.09));
}

/* Palettes now have real two-hue contrast so gradients actually gradient */
html[data-palette="sunset"]{ --rose:#F09090; --lavender:#E8C87A }   /* coral → gold */
html[data-palette="ocean"] { --rose:#7AC8EA; --lavender:#2F5EBD }   /* bright coastal blue → deep ocean navy */
html[data-palette="garden"]{ --rose:#A8C3A0; --lavender:#F2B988 }   /* sage → apricot */
html[data-palette="mono"]  { --rose:#C8C1CC; --lavender:#A89AC6 }   /* pale gray → soft lavender */
html[data-theme="light"][data-palette="sunset"]{ --rose:#C45B4A; --lavender:#B8944A }
html[data-theme="light"][data-palette="ocean"] { --rose:#3A8FBF; --lavender:#1E488F }
html[data-theme="light"][data-palette="garden"]{ --rose:#5A8C4F; --lavender:#D97B3C }
html[data-theme="light"][data-palette="mono"]  { --rose:#6B606F; --lavender:#7563A5 }

/* SHELL */
.ft-app{min-height:100dvh;padding-top:calc(var(--top-h) + env(safe-area-inset-top,0));padding-bottom:calc(var(--nav-h) + env(safe-area-inset-bottom,0) + 16px)}

/* TOP BAR */
.ft-topbar{position:fixed;top:0;left:0;right:0;height:calc(var(--top-h) + env(safe-area-inset-top,0));padding-top:env(safe-area-inset-top,0);display:flex;align-items:center;justify-content:space-between;padding-left:18px;padding-right:18px;z-index:40;isolation:isolate;background:var(--bg-base)}
.ft-topbar::before{content:'';position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,color-mix(in oklab,var(--rose) 12%,var(--bg-base)) 0%,color-mix(in oklab,var(--bg-base) 82%,transparent) 100%);backdrop-filter:blur(20px) saturate(1.2);-webkit-backdrop-filter:blur(20px) saturate(1.2)}
.ft-top-title{font-family:'Playfair Display',serif;font-weight:700;font-size:17px;letter-spacing:-.01em;background:linear-gradient(110deg,var(--apricot),var(--rose),var(--lavender),var(--rose),var(--apricot));background-size:300% 300%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:ft-title-shimmer 14s ease-in-out infinite}
@keyframes ft-title-shimmer{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.ft-top-date{font-family:'Caveat',cursive;font-size:14px;color:var(--text3);margin-top:-2px}
.ft-top-avatars{display:flex;gap:-6px;align-items:center}
.ft-top-avatars .avatar:not(:first-child){margin-left:-8px}

/* BOTTOM NAV */
.ft-nav{position:fixed;left:0;right:0;bottom:0;height:calc(var(--nav-h) + env(safe-area-inset-bottom,0));padding-bottom:env(safe-area-inset-bottom,0);z-index:40;display:flex;align-items:stretch;justify-content:space-around;border-top:1px solid var(--border);isolation:isolate;background:var(--bg2-base)}
.ft-nav::before{content:'';position:absolute;inset:0;z-index:-1;background:linear-gradient(0deg,color-mix(in oklab,var(--lavender) 12%,var(--bg2-base)) 0%,color-mix(in oklab,var(--bg2-base) 85%,transparent) 100%);backdrop-filter:blur(24px) saturate(1.3);-webkit-backdrop-filter:blur(24px) saturate(1.3)}
.ft-nav-btn{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--text3);font-size:10px;font-weight:500;letter-spacing:.02em;padding:8px 2px;transition:color .2s;position:relative}
.ft-nav-btn span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.ft-nav-btn.a{color:var(--text)}
.ft-nav-btn.a::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:24px;height:2px;border-radius:0 0 3px 3px;background:linear-gradient(90deg,var(--rose),var(--lavender));box-shadow:0 0 10px color-mix(in oklab,var(--rose) 50%,transparent)}
.ft-nav-btn svg{transition:transform .2s}
.ft-nav-btn.a svg{transform:translateY(-1px) scale(1.05);color:var(--rose)}

/* SCREEN */
.ft-screen{max-width:520px;margin:0 auto;padding:16px 16px 8px}
.ft-screen-title{font-family:'Playfair Display',serif;font-size:30px;font-weight:700;letter-spacing:-.02em;line-height:1.1;margin-bottom:4px}
.ft-screen-sub{font-family:'Caveat',cursive;font-size:18px;color:var(--text2);margin-bottom:20px}
.ft-section-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.12em;font-weight:600;margin:20px 0 10px 4px;display:flex;align-items:center;gap:8px}
.ft-section-label::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,var(--border2),transparent)}
.ft-section-label.ft-collapsible{transition:color .15s}
.ft-section-label.ft-collapsible:hover{color:var(--text2)}
.ft-collapse-arrow{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;margin-left:auto;margin-right:2px;font-size:13px;color:var(--text2);background:color-mix(in oklab,var(--rose) 10%,var(--card));border:1px solid var(--border);transition:transform .2s,background .2s;font-weight:600;text-transform:none;letter-spacing:normal;line-height:1;order:99}
.ft-section-label.ft-collapsible:hover .ft-collapse-arrow{background:color-mix(in oklab,var(--rose) 18%,var(--card));transform:scale(1.08)}

/* CARD */
.ft-card{background:var(--card);backdrop-filter:blur(18px) saturate(1.1);-webkit-backdrop-filter:blur(18px) saturate(1.1);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--ring);padding:16px;transition:all .22s cubic-bezier(.4,0,.2,1)}
.ft-card.hoverable:hover{background:var(--card-h);border-color:var(--border2);transform:translateY(-1px);box-shadow:var(--sh2),var(--ring)}
.ft-card.hoverable:active{transform:translateY(0) scale(.995)}

/* BTN */
.ft-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border-radius:12px;font-weight:600;letter-spacing:-.005em;transition:all .2s,transform .1s;white-space:nowrap;-webkit-tap-highlight-color:transparent}
.ft-btn:active{transform:scale(.97)}
.ft-item-cb:active{transform:scale(.88)}
@keyframes ft-fade-in{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.ft-btn:active{transform:scale(.96)}
.ft-btn-solid{background:linear-gradient(135deg,var(--rose),var(--lavender));color:#fff;box-shadow:0 2px 10px color-mix(in oklab,var(--rose) 25%,transparent),inset 0 1px 0 rgba(255,255,255,.2)}
.ft-btn-solid:hover{filter:brightness(1.08);transform:translateY(-1px)}
.ft-btn-ghost{background:var(--card);border:1px solid var(--border2);color:var(--text);backdrop-filter:blur(8px)}
.ft-btn-ghost:hover{background:var(--card-h);border-color:var(--border-accent)}
.ft-btn-soft{background:color-mix(in oklab,var(--lavender) 14%,transparent);color:var(--lavender);border:1px solid color-mix(in oklab,var(--lavender) 22%,transparent)}
.ft-btn-danger{background:rgba(240,144,144,.12);color:var(--coral);border:1px solid rgba(240,144,144,.25)}
.ft-btn-sm{padding:7px 14px;font-size:12px}
.ft-btn-md{padding:11px 18px;font-size:14px}
.ft-btn-lg{padding:14px 22px;font-size:15px}

/* INPUT */
.ft-input,.ft-select,.ft-textarea{width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--border2);background:var(--card);color:var(--text);font-size:14px;outline:none;transition:all .2s;font-family:inherit}
.ft-input::placeholder{color:var(--text3)}
.ft-input:focus,.ft-select:focus,.ft-textarea:focus{border-color:var(--border-accent);box-shadow:0 0 0 4px color-mix(in oklab,var(--rose) 08%,transparent)}
.ft-textarea{resize:none;min-height:90px;line-height:1.5}
.ft-label{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text2);font-weight:600;margin-bottom:6px;display:block}

/* SEARCH */
.ft-search{position:relative;margin-bottom:14px}
.ft-search input{padding-left:40px}
.ft-search svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text3)}

/* HOME — tonight hero */
.ft-hero{background:linear-gradient(135deg,color-mix(in oklab,var(--rose) 20%,transparent),color-mix(in oklab,var(--lavender) 16%,transparent) 50%,color-mix(in oklab,var(--apricot) 12%,transparent));border:1px solid var(--border-accent);border-radius:var(--radius-lg);padding:16px 18px;position:relative;overflow:hidden;box-shadow:var(--ring),0 8px 32px color-mix(in oklab,var(--rose) 12%,transparent)}
.ft-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(400px 200px at 80% -20%,rgba(232,200,122,.18),transparent 60%);pointer-events:none}
.ft-hero-eyebrow{font-family:'Caveat',cursive;font-size:17px;color:var(--rose);margin-bottom:4px}
.ft-hero h2,.ft-hero-title{font-family:'Playfair Display',serif;font-size:23px;font-weight:700;letter-spacing:-.02em;line-height:1.15;margin-bottom:10px;min-height:27px}
.ft-hero-row .ft-btn{padding:9px 16px;font-size:13.5px}
.ft-hero-title{animation:ft-hero-in .28s cubic-bezier(.22,1,.36,1)}
.ft-hero.shuffling .ft-hero-title{animation:ft-hero-blur .14s ease-in-out infinite alternate}
.ft-hero.shuffling::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,color-mix(in oklab,var(--rose) 18%,transparent),transparent 65%);animation:ft-pulse .7s ease-in-out infinite;pointer-events:none}
@keyframes ft-hero-in{from{transform:translateY(6px);opacity:0;filter:blur(4px)}to{transform:translateY(0);opacity:1;filter:blur(0)}}
@keyframes ft-hero-blur{from{filter:blur(0) brightness(1);transform:translateY(0)}to{filter:blur(2px) brightness(1.15);transform:translateY(-1px)}}
@keyframes ft-pulse{0%,100%{opacity:.4}50%{opacity:1}}
.ft-hero-meta{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.ft-chip{font-size:11px;padding:3px 10px;border-radius:99px;background:rgba(255,255,255,.06);color:var(--text2);border:1px solid var(--border);letter-spacing:-.003em}
.ft-chip.accent{background:color-mix(in oklab,var(--rose) 14%,transparent);color:var(--rose);border-color:color-mix(in oklab,var(--rose) 25%,transparent)}
.ft-hero-row{display:flex;gap:8px}
.ft-hero-row .ft-btn{flex:1}

/* QUICK ACTIONS */
.ft-qa{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-top:10px}
.ft-qa button{display:flex;flex-direction:column;align-items:center;gap:5px;padding:10px 6px;border-radius:var(--radius);background:var(--card);border:1px solid var(--border);color:var(--text);font-size:11px;font-weight:500;text-align:center;line-height:1.25;cursor:pointer;transition:all .18s;backdrop-filter:blur(12px)}
.ft-qa button:hover{background:var(--card-h);border-color:var(--border-accent);transform:translateY(-1px)}
.ft-qa button:active{transform:scale(.98)}
.ft-qa-ico{width:26px;height:26px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:color-mix(in oklab,var(--lavender) 14%,transparent);color:var(--lavender);flex-shrink:0;font-size:14px}
.ft-qa-ico.rose{background:color-mix(in oklab,var(--rose) 14%,transparent);color:var(--rose)}
.ft-qa-ico.gold{background:rgba(232,200,122,.14);color:var(--gold)}
.ft-qa-ico.teal{background:rgba(139,184,180,.14);color:var(--teal)}
.ft-qa-ico.apricot{background:rgba(242,185,136,.14);color:var(--apricot)}
.ft-qa-ico.lav{background:color-mix(in oklab,var(--lavender) 14%,transparent);color:var(--lavender);font-size:17px}

/* THIS OR THAT */
.ft-tot{position:relative;overflow:hidden;border-radius:16px;border:1px solid var(--border2);background:var(--card);padding:0;cursor:pointer;transition:all .25s cubic-bezier(.22,1,.36,1);aspect-ratio:3/4;display:flex}
.ft-tot:hover{border-color:var(--border-accent);transform:translateY(-2px);box-shadow:0 12px 28px rgba(0,0,0,.35)}
.ft-tot-bd{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.35;filter:saturate(1.2);z-index:0}
.ft-tot-bd::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 20%,rgba(13,11,20,.85) 90%)}
[data-theme="light"] .ft-tot-bd::after{background:linear-gradient(180deg,transparent 20%,rgba(250,245,240,.95) 90%)}
.ft-tot-inner{position:relative;z-index:1;padding:12px;display:flex;flex-direction:column;gap:6px;width:100%;height:100%;justify-content:flex-end;text-align:left;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.4) 100%)}
[data-theme="light"] .ft-tot-inner{background:linear-gradient(180deg,transparent 50%,rgba(255,255,255,.6) 100%)}
.ft-tot-poster{position:absolute;top:10px;left:50%;transform:translateX(-50%);width:88px;height:132px;border-radius:10px;object-fit:cover;box-shadow:0 6px 16px rgba(0,0,0,.45);z-index:0}
.ft-tot-glyph{position:absolute;top:30px;left:50%;transform:translateX(-50%);font-size:56px;opacity:.6;z-index:0}
.ft-tot-cat{font-size:9.5px;color:var(--text3);text-transform:uppercase;letter-spacing:.12em;font-weight:600;margin-top:auto}
.ft-tot-text{font-family:'Playfair Display',serif;font-size:15px;font-weight:700;letter-spacing:-.01em;line-height:1.18;color:var(--text);word-break:break-word;text-wrap:pretty}
.ft-tot-rating{font-size:11px;color:var(--gold);font-weight:700}

/* SURPRISE */
.ft-surprise{position:relative;overflow:hidden;border-radius:18px;border:1px solid var(--border2);background:var(--card);min-height:320px;transition:opacity .3s}
.ft-surprise-bd{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.5;filter:saturate(1.2) blur(2px);z-index:0;animation:ft-surprise-in .6s ease}
.ft-surprise-bd::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,11,20,.5) 0%,rgba(13,11,20,.92) 90%)}
[data-theme="light"] .ft-surprise-bd::after{background:linear-gradient(180deg,rgba(250,245,240,.55) 0%,rgba(250,245,240,.94) 90%)}
.ft-surprise-inner{position:relative;z-index:1;padding:24px 22px 22px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px}
.ft-surprise-poster{width:110px;height:165px;border-radius:12px;object-fit:cover;box-shadow:0 10px 30px rgba(0,0,0,.5);margin:4px 0 12px;animation:ft-surprise-in .45s cubic-bezier(.22,1,.36,1)}
.ft-surprise-glyph{font-size:64px;margin:10px 0;opacity:.7}
.ft-surprise-cat{font-size:10.5px;color:var(--text3);text-transform:uppercase;letter-spacing:.14em;font-weight:600}
.ft-surprise-title{font-family:'Playfair Display',serif;font-size:24px;font-weight:700;letter-spacing:-.02em;line-height:1.15;margin-top:4px;transition:filter .2s}
.ft-surprise-title.blur{filter:blur(6px)}
.ft-surprise-ov{font-size:12.5px;color:var(--text2);font-style:italic;line-height:1.5;max-width:320px;margin-top:4px}
.ft-surprise-rating{color:var(--gold);font-weight:700;letter-spacing:.02em;margin-top:6px;font-size:13px}
@keyframes ft-surprise-in{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}

/* LIST — category chips (sticky under topbar) */
.ft-catrow-sticky{position:sticky;top:calc(var(--top-h) + env(safe-area-inset-top,0));z-index:25;margin:-4px -16px 4px;padding:6px 16px 2px;background:var(--bg);border-bottom:1px solid var(--border)}
.ft-catrow-sticky::before{content:'';position:absolute;left:0;right:0;bottom:-12px;height:12px;background:linear-gradient(to bottom,var(--bg),transparent);pointer-events:none}
.ft-catrow{display:flex;gap:6px;overflow-x:auto;padding:4px 0 10px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.ft-catrow::-webkit-scrollbar{display:none}
.ft-catchip{flex-shrink:0;padding:7px 14px;border-radius:99px;background:var(--card);border:1px solid var(--border);color:var(--text2);font-size:12.5px;font-weight:500;white-space:nowrap;transition:all .2s;letter-spacing:-.005em;backdrop-filter:blur(10px)}
.ft-catchip:hover{color:var(--text)}
.ft-catchip.a{color:var(--text);background:var(--card-strong);border-color:var(--border-accent);box-shadow:0 0 0 3px color-mix(in oklab,var(--rose) 08%,transparent)}
.ft-catchip.edit{animation:ft-wiggle 1.8s ease-in-out infinite;border-style:dashed}
.ft-catchip.new{color:var(--rose);border-style:dashed;border-color:var(--border-accent);background:transparent}
.ft-catchip.new:hover{background:color-mix(in oklab,var(--rose) 08%,transparent)}
@keyframes ft-wiggle{0%,100%{transform:rotate(-.6deg)}50%{transform:rotate(.6deg)}}

/* PLAY SCREEN */
.ft-play-board{background:linear-gradient(135deg,color-mix(in oklab,var(--rose) 14%,transparent),color-mix(in oklab,var(--lavender) 14%,transparent) 50%,color-mix(in oklab,var(--apricot) 10%,transparent));border:1px solid var(--border-accent);border-radius:var(--radius-lg);padding:22px 18px;box-shadow:var(--ring),0 8px 32px color-mix(in oklab,var(--rose) 12%,transparent);position:relative;overflow:hidden}
.ft-play-board::before{content:'';position:absolute;inset:0;background:radial-gradient(300px 200px at 100% 0%,rgba(232,200,122,.15),transparent 60%);pointer-events:none}
.ft-play-game-label{display:flex;align-items:center;gap:9px;margin:-4px 0 18px;position:relative;z-index:1}
.ft-play-game-tiles{font-size:17px;filter:saturate(1.1)}
.ft-play-game-name{font-family:'Playfair Display',serif;font-weight:700;font-size:16px;letter-spacing:-.01em;background:linear-gradient(110deg,var(--apricot),var(--rose),var(--lavender));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ft-play-game-line{flex:1;height:1px;background:linear-gradient(90deg,var(--border-accent),transparent)}
.ft-play-game-total{font-size:10.5px;color:var(--text3);letter-spacing:.1em;text-transform:uppercase;font-weight:600}
.ft-play-vs{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:18px;position:relative}
.ft-play-side{flex:1;text-align:center;max-width:140px;position:relative}
.ft-play-side .avatar{margin:0 auto 8px}
.ft-play-num{font-family:'Playfair Display',serif;font-size:44px;font-weight:700;letter-spacing:-.03em;line-height:1;background:linear-gradient(135deg,var(--rose),var(--lavender));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.ft-play-name{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);margin-top:4px;font-weight:600}
.ft-play-fire{position:absolute;top:-6px;right:10px;font-size:11px;color:var(--gold);background:rgba(232,200,122,.15);padding:2px 7px;border-radius:99px;border:1px solid rgba(232,200,122,.3);font-weight:600}
.ft-play-vs-text{font-family:'Playfair Display',serif;font-style:italic;font-size:20px;color:var(--text3);padding:0 4px}
.ft-play-bar{position:relative;height:6px;border-radius:99px;background:rgba(255,255,255,.06);overflow:hidden;margin-bottom:14px}
.ft-play-bar-fill{height:100%;background:linear-gradient(90deg,var(--rose),var(--lavender));border-radius:99px;transition:width .6s cubic-bezier(.22,1,.36,1)}
.ft-play-bar-lbl{position:absolute;top:-18px;font-size:10px;color:var(--text3);letter-spacing:.05em}
.ft-play-bar-lbl.l{left:0}
.ft-play-bar-lbl.r{right:0}
.ft-play-actions{display:flex;gap:8px}

.ft-streak-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.ft-streak-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px 12px;text-align:center;position:relative;backdrop-filter:blur(12px)}
.ft-streak-card .avatar{margin:0 auto 8px}
.ft-streak-flame{position:absolute;top:10px;right:12px;font-size:18px;filter:drop-shadow(0 0 8px rgba(242,185,136,.6))}
.ft-streak-n{font-family:'Playfair Display',serif;font-size:28px;font-weight:700;letter-spacing:-.015em;color:var(--apricot)}
.ft-streak-l{font-size:11px;color:var(--text3);margin-top:2px}

.ft-ach-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
@media(min-width:420px){.ft-ach-grid{grid-template-columns:repeat(3,1fr)}}
.ft-ach{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 12px 16px;text-align:center;opacity:.5;transition:all .25s;backdrop-filter:blur(10px);min-height:110px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start}
.ft-ach.on{opacity:1;border-color:var(--border-accent);background:linear-gradient(135deg,color-mix(in oklab,var(--rose) 08%,transparent),color-mix(in oklab,var(--lavender) 06%,transparent));box-shadow:0 0 0 3px color-mix(in oklab,var(--rose) 05%,transparent)}
.ft-ach-ico{font-size:28px;margin-bottom:6px;filter:grayscale(1);transition:filter .25s;line-height:1}
.ft-ach.on .ft-ach-ico{filter:none}
.ft-ach-ttl{font-family:'Playfair Display',serif;font-size:13px;font-weight:700;letter-spacing:-.01em;margin-bottom:4px;line-height:1.15}
.ft-ach-sub{font-size:10.5px;color:var(--text3);line-height:1.35}

/* NUDGE CARD (inside expanded item) */
.ft-nc{margin-top:10px;padding:12px;border-radius:12px;background:color-mix(in oklab,var(--lavender) 06%,transparent);border:1px solid color-mix(in oklab,var(--lavender) 22%,transparent)}
.ft-nc-top{display:flex;gap:10px;margin-bottom:8px}
.ft-nc-photo{width:72px;height:72px;border-radius:10px;object-fit:cover;flex-shrink:0;background:var(--card-strong)}
.ft-nc-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.ft-nc-hood{font-size:11.5px;color:var(--text2);display:flex;align-items:center;gap:4px}
.ft-nc-rating{font-size:11.5px;color:var(--gold);font-weight:600}
.ft-nc-hours{font-size:11px;color:var(--text3)}
.ft-nc-pull{font-size:12.5px;font-style:italic;color:var(--text);line-height:1.5;border-left:2px solid var(--border-accent);padding:2px 0 2px 10px;margin:8px 0}
.ft-nc-desc{font-size:12.5px;color:var(--text2);line-height:1.5;margin:6px 0}
.ft-nc-addr{font-size:11px;color:var(--text3);margin-top:6px;display:flex;align-items:center;gap:4px}
.ft-nc-near{margin-top:8px;padding-top:8px;border-top:1px dashed var(--border)}
.ft-nc-near-title{font-size:9.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);font-weight:600;margin-bottom:4px}
.ft-nc-near-list{font-size:11.5px;color:var(--text2);line-height:1.5}
.ft-nc-link{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;color:var(--lavender);margin-top:8px;text-decoration:none;font-weight:500}
.ft-nc-link:hover{color:var(--rose)}

/* ITEM CARD */
.ft-item{display:flex;gap:12px;padding:14px;border-radius:var(--radius);background:var(--card);border:1px solid var(--border);margin-bottom:8px;transition:all .22s;position:relative;backdrop-filter:blur(14px)}
.ft-item:hover{background:var(--card-h);border-color:var(--border2);transform:translateY(-1px);box-shadow:var(--sh1)}
.ft-item.done{opacity:.55}
.ft-item.done .ft-item-text{text-decoration:line-through;text-decoration-color:var(--text3);color:var(--text3)}
.ft-item-cb{width:24px;height:24px;border-radius:8px;border:1.5px solid var(--border2);background:var(--card);flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;color:transparent;transition:all .2s;cursor:pointer}
.ft-item-cb:hover{border-color:var(--border-accent)}
.ft-item-cb.checked{background:linear-gradient(135deg,var(--rose),var(--lavender));border-color:transparent;color:#fff;box-shadow:0 0 0 3px color-mix(in oklab,var(--rose) 15%,transparent)}
.ft-item-body{flex:1;min-width:0}
.ft-item-text{font-size:14.5px;line-height:1.4;color:var(--text);word-break:break-word}
.ft-item-meta{display:flex;gap:6px;align-items:center;margin-top:6px;flex-wrap:wrap;font-size:11px;color:var(--text3)}
.ft-item-meta .avatar{margin-right:-2px}
.ft-item-poster{width:52px;height:74px;border-radius:8px;overflow:hidden;flex-shrink:0;background:var(--card-strong);box-shadow:var(--sh1)}
.ft-item-poster img{width:100%;height:100%;object-fit:cover;display:block}
.ft-badge{font-size:10px;padding:2px 8px;border-radius:99px;letter-spacing:.02em}
.ft-badge-status{background:rgba(139,184,180,.14);color:var(--teal)}
.ft-badge-tag{background:color-mix(in oklab,var(--lavender) 14%,transparent);color:var(--lavender)}
.ft-badge-mood{background:color-mix(in oklab,var(--rose) 12%,transparent);color:var(--rose);font-style:italic}

/* MEDIA ITEM (movies/TV with TMDB data) */
.ft-mitem{position:relative;border-radius:var(--radius);overflow:hidden;margin-bottom:10px;border:1px solid var(--border);background:var(--card);transition:all .22s;backdrop-filter:blur(14px)}
.ft-mitem:hover{border-color:var(--border2);transform:translateY(-1px);box-shadow:var(--sh2)}
.ft-mitem.done{opacity:.55}
.ft-mitem.done .ft-mitem-title{text-decoration:line-through;text-decoration-color:var(--text3);color:var(--text3)}
.ft-mitem-bd{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.22;filter:saturate(1.1) blur(.5px);z-index:0;border-radius:inherit}
.ft-mitem-bd::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,var(--card-strong) 0%,rgba(0,0,0,.45) 40%,rgba(0,0,0,.15) 100%)}

/* Landscape banner layout (for og_image / nudge cards with horizontal-ish photos) */
.ft-mitem.landscape{display:flex;flex-direction:column}
.ft-mitem.landscape .ft-mitem-hero{position:relative;width:100%;height:160px;overflow:hidden;border-radius:var(--radius) var(--radius) 0 0}
.ft-mitem.landscape .ft-mitem-hero img{width:100%;height:100%;object-fit:cover;display:block}
.ft-mitem.landscape .ft-mitem-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.55) 100%)}
.ft-mitem.landscape .ft-mitem-hero-cb{position:absolute;top:10px;left:10px;z-index:2}
.ft-mitem.landscape .ft-mitem-hero-title{position:absolute;bottom:10px;left:14px;right:14px;z-index:2;font-family:'Playfair Display',serif;font-size:17px;font-weight:700;color:#fff;letter-spacing:-.01em;line-height:1.15;text-shadow:0 2px 8px rgba(0,0,0,.4)}
.ft-mitem.landscape .ft-mitem-hero-tap{cursor:pointer;-webkit-tap-highlight-color:transparent}
.ft-mitem.landscape .ft-mitem-hero-hint{position:absolute;bottom:10px;right:10px;z-index:2;width:22px;height:22px;border-radius:50%;background:rgba(0,0,0,.55);backdrop-filter:blur(6px);color:#fff;font-size:12px;font-weight:700;display:grid;place-items:center}
.ft-mitem.landscape .ft-mitem-below{padding:12px 14px 14px}
.ft-mitem-inner{position:relative;z-index:1;display:block;padding:14px;background:linear-gradient(90deg,rgba(13,11,20,.55) 0%,rgba(13,11,20,.25) 100%)}
.ft-mitem-inner::after{content:'';display:table;clear:both}
.ft-mitem-inner > .ft-item-cb{float:left;margin-right:10px}
.ft-mitem-inner > .ft-mitem-poster{float:left;margin-right:12px;margin-bottom:8px}
.ft-mitem-body{display:block;min-width:0}
[data-theme="light"] .ft-mitem-inner{background:linear-gradient(90deg,rgba(250,245,240,.85) 0%,rgba(250,245,240,.55) 100%)}
.ft-mitem-poster{width:64px;height:96px;border-radius:10px;overflow:hidden;flex-shrink:0;box-shadow:0 4px 14px rgba(0,0,0,.4);background:var(--card-strong);position:relative;align-self:flex-start}
.ft-mitem-poster img{width:100%;height:100%;object-fit:cover}
.ft-mitem-poster img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s cubic-bezier(.4,0,.2,1)}
.ft-mitem-poster-tappable{cursor:pointer;-webkit-tap-highlight-color:transparent}
.ft-mitem-poster-tappable:active img{transform:scale(.96)}
.ft-mitem-poster-hint{position:absolute;bottom:5px;right:5px;width:22px;height:22px;border-radius:50%;background:rgba(0,0,0,.72);backdrop-filter:blur(6px);color:#fff;font-size:13px;font-weight:700;display:grid;place-items:center;box-shadow:0 2px 8px rgba(0,0,0,.4);opacity:.92;transition:opacity .2s,transform .2s}
.ft-mitem-poster-tappable:hover .ft-mitem-poster-hint{opacity:1;transform:scale(1.1)}
.ft-mitem-details-chip{display:inline-flex;align-items:center;gap:3px;font-size:10.5px;font-weight:600;padding:2.5px 9px;border-radius:99px;background:linear-gradient(135deg,color-mix(in oklab,var(--lavender) 22%,transparent),color-mix(in oklab,var(--rose) 18%,transparent));color:var(--lavender);border:1px solid color-mix(in oklab,var(--lavender) 35%,transparent);cursor:pointer;letter-spacing:.01em;transition:transform .15s,box-shadow .15s,background .2s;-webkit-tap-highlight-color:transparent}
.ft-mitem-details-chip:hover{background:linear-gradient(135deg,color-mix(in oklab,var(--lavender) 32%,transparent),color-mix(in oklab,var(--rose) 26%,transparent));box-shadow:0 2px 8px color-mix(in oklab,var(--lavender) 25%,transparent)}
.ft-mitem-details-chip:active{transform:scale(.94)}
.ft-mitem-body{flex:1;min-width:0}
.ft-mitem-title{font-family:'Playfair Display',serif;font-size:16px;font-weight:700;letter-spacing:-.01em;line-height:1.2;margin-bottom:5px}
.ft-mitem-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:5px;font-size:11px}
.ft-mitem-year{color:var(--text2);font-weight:500}
.ft-mitem-rating{color:var(--gold);font-weight:700;letter-spacing:.01em}
.ft-mitem-type{font-size:9.5px;padding:2px 7px;border-radius:99px;background:color-mix(in oklab,var(--lavender) 15%,transparent);color:var(--lavender);text-transform:uppercase;letter-spacing:.1em;font-weight:600}
.ft-mitem-ov{font-size:12px;color:var(--text2);line-height:1.45;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden;font-style:italic;opacity:.92;word-break:break-word}

/* MEMORIES */
.ft-mem-month{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;letter-spacing:-.015em;margin:22px 0 10px 4px;display:flex;align-items:baseline;gap:10px}
.ft-mem-month .count{font-family:'Caveat',cursive;font-weight:500;font-size:16px;color:var(--text3)}
.ft-mem{display:flex;gap:14px;padding:16px;border-radius:var(--radius);background:var(--card);border:1px solid var(--border);margin-bottom:10px;backdrop-filter:blur(14px);transition:all .22s;position:relative;overflow:hidden}
.ft-mem:hover{background:var(--card-h);border-color:var(--border2);transform:translateY(-1px);box-shadow:var(--sh2)}
.ft-mem::before{content:'';position:absolute;left:0;top:20%;bottom:20%;width:2px;border-radius:0 2px 2px 0;background:linear-gradient(180deg,var(--rose),var(--lavender))}
.ft-mem-img{width:72px;height:96px;border-radius:8px;overflow:hidden;flex-shrink:0;background:var(--card-strong)}
.ft-mem-img img{width:100%;height:100%;object-fit:cover}
.ft-mem-body{flex:1;min-width:0}
.ft-mem-date{font-family:'Caveat',cursive;font-size:14px;color:var(--text3)}
.ft-mem-title{font-family:'Playfair Display',serif;font-size:16px;font-weight:700;line-height:1.2;margin:2px 0 6px;letter-spacing:-.01em}
.ft-mem-who{display:flex;gap:6px;align-items:center;font-size:11px;color:var(--text2);margin-top:6px}
.ft-mem-placeholder{width:72px;height:96px;border-radius:8px;background:linear-gradient(135deg,color-mix(in oklab,var(--rose) 15%,transparent),color-mix(in oklab,var(--lavender) 15%,transparent));flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:32px;opacity:.7}
.ft-mem-fav{position:absolute;top:10px;right:10px;width:32px;height:32px;border-radius:50%;border:none;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;line-height:1;font-family:inherit;background:rgba(255,255,255,.88);color:#b86a8a;box-shadow:0 2px 8px rgba(0,0,0,.18),0 0 0 1px rgba(0,0,0,.04);transition:transform .15s cubic-bezier(.22,1,.36,1),background .2s,color .2s}
[data-theme="dark"] .ft-mem-fav{background:rgba(30,24,40,.85);color:var(--text2);box-shadow:0 2px 8px rgba(0,0,0,.35),0 0 0 1px rgba(255,220,230,.1)}
.ft-mem-fav:hover{transform:scale(1.12)}
.ft-mem-fav:active{transform:scale(.92)}
.ft-mem-fav.on{background:linear-gradient(135deg,var(--rose),var(--lavender));color:#fff;box-shadow:0 2px 10px color-mix(in oklab,var(--rose) 55%,transparent),0 0 0 1px rgba(255,255,255,.3) inset}
.ft-mem-fav.on:hover{transform:scale(1.12);box-shadow:0 4px 14px color-mix(in oklab,var(--rose) 65%,transparent),0 0 0 1px rgba(255,255,255,.3) inset}

/* US SCREEN */
.ft-profile-card{text-align:center;padding:16px 18px}
.ft-profile-names{display:flex;justify-content:center;gap:12px;margin-bottom:10px}
.ft-profile-name{text-align:center}
.ft-profile-name .avatar{margin:0 auto 6px}
.ft-profile-name-text{font-family:'Playfair Display',serif;font-size:14px;font-weight:700}
.ft-profile-name-role{font-family:'Caveat',cursive;font-size:12px;color:var(--text3)}
.ft-profile-amp{align-self:center;font-family:'Playfair Display',serif;font-style:italic;font-size:18px;color:var(--text3);margin-top:14px}

.ft-stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px}
.ft-stat{text-align:center;padding:9px 6px;border-radius:var(--radius-sm);background:var(--card);border:1px solid var(--border)}
.ft-stat-n{font-family:'Playfair Display',serif;font-size:20px;font-weight:700;color:var(--text);letter-spacing:-.015em}
.ft-stat-l{font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);margin-top:2px}

/* FAB */
.ft-fab{position:fixed;bottom:calc(var(--nav-h) + env(safe-area-inset-bottom,0) + 16px);right:18px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--rose),var(--lavender));color:#fff;box-shadow:0 8px 24px color-mix(in oklab,var(--rose) 35%,transparent),0 2px 8px rgba(0,0,0,.3),inset 0 1px 0 rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;transition:transform .25s cubic-bezier(.22,1,.36,1),box-shadow .25s cubic-bezier(.22,1,.36,1),opacity .2s ease;z-index:35;touch-action:none;user-select:none;-webkit-user-select:none;cursor:grab}
.ft-fab:hover{transform:scale(1.08) translateY(-2px);box-shadow:0 12px 32px color-mix(in oklab,var(--rose) 45%,transparent)}
.ft-fab:active{transform:scale(.95)}
.ft-fab.ft-fab-dragging{transition:none;cursor:grabbing;transform:scale(1.12);box-shadow:0 16px 40px color-mix(in oklab,var(--rose) 55%,transparent),0 4px 12px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.35);opacity:.95}

/* Subtle seasonal accent — a gentle tint blended over the background. */
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:0;opacity:0;transition:opacity .4s ease,background .4s ease}
html[data-season="fall"]   body::before{opacity:.04;background:radial-gradient(ellipse at top,rgba(242,185,136,.6) 0%,transparent 55%),radial-gradient(ellipse at bottom right,color-mix(in oklab,var(--rose) 40%,transparent) 0%,transparent 60%)}
html[data-season="winter"] body::before{opacity:.035;background:radial-gradient(ellipse at top,rgba(164,195,227,.6) 0%,transparent 55%),radial-gradient(ellipse at bottom,color-mix(in oklab,var(--lavender) 50%,transparent) 0%,transparent 60%)}
html[data-season="spring"] body::before{opacity:.035;background:radial-gradient(ellipse at top,color-mix(in oklab,var(--rose) 55%,transparent) 0%,transparent 55%),radial-gradient(ellipse at bottom,color-mix(in oklab,var(--lavender) 40%,transparent) 0%,transparent 60%)}
html[data-season="summer"] body::before{opacity:.035;background:radial-gradient(ellipse at top,rgba(232,200,122,.55) 0%,transparent 55%),radial-gradient(ellipse at bottom,rgba(242,185,136,.45) 0%,transparent 60%)}
html[data-theme="light"][data-season="fall"]   body::before{opacity:.06}
html[data-theme="light"][data-season="winter"] body::before{opacity:.055}
html[data-theme="light"][data-season="spring"] body::before{opacity:.06}
html[data-theme="light"][data-season="summer"] body::before{opacity:.055}
/* Block all interactions briefly after FAB release so drop-on-card doesn't trigger card */
html.ft-fab-just-dragged *{pointer-events:none!important}
html.ft-fab-just-dragged .ft-fab,html.ft-fab-just-dragged .ft-fab *{pointer-events:auto!important}

/* SHEET */
.ft-sheet-ov{position:fixed;inset:0;z-index:100;background:rgba(10,8,18,.65);backdrop-filter:blur(8px);display:flex;align-items:flex-end;justify-content:center;animation:fade .18s ease;overscroll-behavior:contain;touch-action:none}
.ft-sheet{background:var(--bg2);border-radius:22px 22px 0 0;padding:10px 18px calc(var(--nav-h) + env(safe-area-inset-bottom,0) + 20px);width:100%;max-width:520px;animation:up .28s cubic-bezier(.22,1,.36,1);border-top:1px solid var(--border2);box-shadow:0 -12px 40px rgba(0,0,0,.5);max-height:90vh;overflow-y:auto;transform:translate3d(0,0,0);backface-visibility:hidden;overscroll-behavior:none;-webkit-overflow-scrolling:touch;touch-action:pan-y}
.ft-sheet.dragging{transition:none!important}
.ft-sheet-ov{-webkit-tap-highlight-color:transparent}
.ft-sheet-handle{width:40px;height:4px;border-radius:99px;background:var(--border2);margin:6px auto 14px}
.ft-sheet-title{font-family:'Playfair Display',serif;font-weight:700;font-size:18px;margin-bottom:14px;letter-spacing:-.01em}

/* MODAL */
.ft-modal-ov{position:fixed;inset:0;z-index:100;background:rgba(10,8,18,.70);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;padding:16px;animation:fade .18s ease}
.ft-modal{background:var(--bg2);border-radius:22px;padding:22px;width:100%;max-width:400px;border:1px solid var(--border2);max-height:90vh;overflow-y:auto;animation:pop .26s cubic-bezier(.22,1,.36,1);box-shadow:var(--sh3)}
.ft-modal.wide{max-width:520px}
.ft-modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.ft-modal-head h3{font-family:'Playfair Display',serif;font-weight:700;font-size:19px;letter-spacing:-.01em}
.ft-close-btn{width:30px;height:30px;border-radius:50%;background:var(--card);border:1px solid var(--border);color:var(--text2);display:flex;align-items:center;justify-content:center;transition:all .2s}
.ft-close-btn:hover{background:var(--card-h);color:var(--text);transform:rotate(90deg)}

@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes up{from{transform:translateY(100%)}to{transform:translateY(0)}}
@keyframes pop{from{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}

/* EMPTY */
.ft-empty{text-align:center;padding:56px 20px;color:var(--text3)}
.ft-empty-glyph{font-size:36px;margin-bottom:10px;opacity:.6;letter-spacing:.4em}
.ft-empty-text{font-family:'Caveat',cursive;font-size:18px;line-height:1.4}

/* ACTIVITY PILL */
.ft-activity-row{display:flex;gap:10px;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--border);font-size:12.5px}
.ft-activity-row:last-child{border-bottom:none}
.ft-activity-text{flex:1;color:var(--text2);line-height:1.4}
.ft-activity-text b{color:var(--text);font-weight:600}
.ft-activity-when{font-size:10px;color:var(--text3);letter-spacing:.02em;white-space:nowrap}

/* AVATAR UPLOAD */
.ft-av-upload{position:relative;display:inline-block;cursor:pointer}
.ft-av-upload input{display:none}
.ft-av-upload .ft-av-badge{position:absolute;right:-2px;bottom:-2px;width:26px;height:26px;border-radius:50%;background:var(--bg2);border:1.5px solid var(--border-accent);display:flex;align-items:center;justify-content:center;color:var(--rose)}

/* SPLASH */
.ft-splash{position:fixed;inset:0;z-index:200;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(600px 400px at 50% 45%,color-mix(in oklab,var(--rose) 16%,transparent),transparent 60%),radial-gradient(500px 400px at 50% 70%,color-mix(in oklab,var(--lavender) 13%,transparent),transparent 60%),linear-gradient(180deg,var(--bg) 0%,var(--bg2) 100%);gap:14px;transition:opacity .4s;padding-bottom:56px}
.ft-splash.hide{opacity:0;pointer-events:none}
.ft-splash-heart{font-size:66px;color:var(--rose);animation:pulse 1.3s ease-in-out infinite;filter:drop-shadow(0 0 30px color-mix(in oklab,var(--rose) 55%,transparent))}
.ft-splash-title{font-family:'Playfair Display',serif;font-size:32px;font-weight:700;letter-spacing:-.02em;background:linear-gradient(110deg,var(--apricot),var(--rose),var(--lavender));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.ft-splash-sub{font-family:'Caveat',cursive;font-size:19px;color:var(--text2)}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}

/* CONFETTI */
#v2Confetti{position:fixed;inset:0;pointer-events:none;z-index:9999}

/* SMALL SCREENS */
@media(max-width:380px){
  .ft-screen-title{font-size:26px}
  .ft-hero h2{font-size:20px}
  .ft-qa{grid-template-columns:repeat(3,1fr)}
}

/* ANIMATED PROGRESS BAR */
.ft-progbar-fill{
  background: linear-gradient(90deg, var(--rose), var(--lavender), var(--apricot), var(--rose));
  background-size: 300% 100%;
  animation: progShimmer 4.5s linear infinite;
  border-radius: 99px;
  position: relative;
  overflow: hidden;
}
.ft-progbar-fill::after{
  content:'';
  position:absolute;
  inset:0;
  background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,.4) 50%, transparent 100%);
  animation: progSheen 2.8s ease-in-out infinite;
}
@keyframes progShimmer {
  0%   {background-position: 0% 50%}
  100% {background-position: 300% 50%}
}
@keyframes progSheen {
  0%   {transform: translateX(-100%)}
  60%  {transform: translateX(200%)}
  100% {transform: translateX(200%)}
}

/* THINKING FANFARE */
.ft-think-glow{
  position:fixed; inset:-20%;
  background: radial-gradient(circle at 50% 40%, color-mix(in oklab,var(--rose) 45%,transparent), transparent 55%);
  pointer-events:none;
  z-index:140;
  animation: thinkGlow 2.4s ease-out forwards;
}
@keyframes thinkGlow {
  0%   {opacity:0; transform:scale(.6)}
  30%  {opacity:1; transform:scale(1)}
  100% {opacity:0; transform:scale(1.4)}
}
.ft-think-ring{
  position:absolute; left:50%; top:38%;
  width:180px; height:180px;
  margin:-90px 0 0 -90px;
  border-radius:50%;
  border:2px solid color-mix(in oklab,var(--rose) 70%,transparent);
  pointer-events:none;
  animation: thinkRing 1.6s ease-out forwards;
}
.ft-think-ring.r2{animation-delay:.25s}
.ft-think-ring.r3{animation-delay:.5s}
@keyframes thinkRing {
  0%   {opacity:0; transform:scale(.3)}
  20%  {opacity:1}
  100% {opacity:0; transform:scale(2.4)}
}
.ft-think-spark{
  position:absolute;
  font-size:22px;
  pointer-events:none;
  animation: thinkSpark 1.8s ease-out forwards;
}
@keyframes thinkSpark {
  0%   {opacity:0; transform:translate(0,0) scale(.4) rotate(0)}
  20%  {opacity:1}
  100% {opacity:0; transform:translate(var(--dx),var(--dy)) scale(1) rotate(360deg)}
}
@keyframes spin{
  from{transform:rotate(0deg)}
  to{transform:rotate(360deg)}
}

.ft-remove-photo-btn{margin-top:8px;display:inline-flex;align-items:center;gap:4px;padding:3px 10px;font-size:10.5px;font-weight:600;border-radius:99px;background:color-mix(in oklab,var(--rose) 14%,transparent);border:1px solid color-mix(in oklab,var(--rose) 30%,transparent);color:var(--rose);cursor:pointer;font-family:inherit;letter-spacing:.02em;transition:transform .15s,background .2s}
.ft-remove-photo-btn:hover{background:color-mix(in oklab,var(--rose) 24%,transparent)}
.ft-remove-photo-btn:active{transform:scale(.94)}


/* ===== Comments (chat bubbles) ===== */
.ft-comments{display:flex;flex-direction:column;gap:10px;margin:4px 0 10px;padding:4px 0}
.ft-comment{display:flex;gap:8px;align-items:flex-start}
.ft-comment.mine{flex-direction:row-reverse}
.ft-comment-avatar{flex-shrink:0;margin-top:2px}
.ft-comment-body{flex:1;min-width:0;display:flex;flex-direction:column;align-items:flex-start;gap:4px}
.ft-comment.mine .ft-comment-body{align-items:flex-end}
.ft-comment-bubble{
  background:var(--card);
  border:1px solid var(--border);
  padding:8px 12px;
  border-radius:16px;
  border-bottom-left-radius:4px;
  max-width:85%;
  word-wrap:break-word;
}
.ft-comment.mine .ft-comment-bubble{
  background:linear-gradient(135deg, color-mix(in oklab,var(--rose) 14%,transparent), color-mix(in oklab,var(--lavender) 10%,transparent));
  border-color:color-mix(in oklab,var(--rose) 30%,transparent);
  border-radius:16px;
  border-bottom-right-radius:4px;
}
.ft-comment-who{font-size:10.5px;color:var(--text3);font-weight:600;letter-spacing:.03em;text-transform:uppercase;margin-bottom:2px}
.ft-comment-text{font-size:13px;color:var(--text);line-height:1.42}
.ft-comment-reactions{display:flex;gap:4px;flex-wrap:wrap;align-items:center;padding:0 4px;position:relative}
.ft-reaction{
  display:inline-flex;align-items:center;gap:3px;
  padding:2px 8px;border-radius:99px;
  background:var(--card);border:1px solid var(--border);
  color:var(--text2);cursor:pointer;font-family:inherit;
  transition:transform .1s;
}
.ft-reaction:active{transform:scale(.9)}
.ft-reaction.mine{background:color-mix(in oklab,var(--rose) 20%,transparent);border-color:color-mix(in oklab,var(--rose) 45%,transparent)}
.ft-reaction-emoji{font-size:12px;line-height:1}
.ft-reaction-count{font-size:10px;color:var(--text3);font-weight:600}
.ft-reaction.mine .ft-reaction-count{color:var(--text2)}
.ft-reaction-add{
  padding:2px 7px;border-radius:99px;
  background:transparent;border:1px dashed var(--border);
  color:var(--text3);cursor:pointer;font-size:11px;font-family:inherit;
  opacity:.7;transition:opacity .15s, background .15s;
}
.ft-reaction-add:hover{opacity:1;background:var(--card)}
.ft-reaction-picker{display:none;gap:2px;margin-left:4px;padding:3px;background:var(--card);border:1px solid var(--border);border-radius:99px;box-shadow:0 4px 16px rgba(0,0,0,.18)}
.ft-reaction-picker button{font-size:16px;padding:2px 5px;border-radius:99px;background:transparent;border:none;cursor:pointer;transition:transform .1s,background .15s}
.ft-reaction-picker button:hover{background:var(--card-strong)}
.ft-reaction-picker button:active{transform:scale(.85)}

/* ACTIVITY FEED SHEET */
.ft-activity-entry{padding:11px 0;border-bottom:1px solid var(--border)}
.ft-activity-entry:last-child{border-bottom:none}
.ft-activity-main{display:flex;gap:10px;align-items:flex-start;padding:4px 0;border-radius:10px;transition:background .15s}
.ft-activity-main:active{background:var(--card-h)}
.ft-activity-reactions{display:flex;gap:4px;flex-wrap:wrap;align-items:center;padding:6px 0 0 38px;position:relative;min-height:0}
.ft-activity-comments{margin:8px 0 0 38px;padding:8px 10px;border-radius:10px;background:var(--card-strong);border:1px solid var(--border)}
.ft-activity-comment{display:flex;gap:8px;align-items:flex-start;padding:6px 0;border-bottom:1px solid var(--border)}
.ft-activity-comment:last-of-type{border-bottom:none}
.ft-activity-comment-input{display:flex;gap:6px;padding-top:6px}
.ft-activity-comment-input input{flex:1;padding:7px 10px;border-radius:10px;border:1px solid var(--border);background:var(--card);color:var(--text);font-size:13px;font-family:inherit;outline:none}
.ft-activity-comment-input input:focus{border-color:var(--border-accent)}
.ft-activity-comment-input button{padding:7px 12px;border-radius:10px;background:linear-gradient(135deg,var(--rose),var(--lavender));color:#fff;border:none;font-size:12px;font-weight:600;cursor:pointer}
.ft-activity-comment-input button:disabled{opacity:.4;cursor:not-allowed;filter:grayscale(.5)}
.ft-comment-toggle{display:inline-flex;align-items:center;gap:3px}
