:root {
  --emotion: #FFD400;
  --emotion-soft: rgba(255,212,0,.28);
  --emotion-mid: rgba(255,212,0,.88);
  --emotion-solid: rgba(255,212,0,1);
  --bg: #020202;
  --panel: rgba(10,10,10,.56);
  --text: rgba(255,255,255,.95);
  --muted: rgba(255,255,255,.58);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:ui-sans-serif,-apple-system,BlinkMacSystemFont,"SF Pro Display","Segoe UI",Arial,sans-serif}
#app{position:fixed;inset:0;background:radial-gradient(circle at 50% 46%, rgba(255,255,255,.05), transparent 33%),radial-gradient(circle at 50% 58%, rgba(255,255,255,.04), transparent 54%),#020202}
#earthCanvas{position:fixed;inset:0;width:100vw;height:100vh;display:block;cursor:grab}
#earthCanvas:active{cursor:grabbing}
.grain,.vignette,.hud,.loading,.hint,.toast,.result,.star-message,.launch-star,.country-tooltip,.rotation-info{position:fixed}
.grain{inset:0;pointer-events:none;opacity:.06;mix-blend-mode:screen;background-image:radial-gradient(circle at 20% 20%, rgba(255,255,255,.45) 0 1px, transparent 1px),radial-gradient(circle at 80% 30%, rgba(255,255,255,.35) 0 1px, transparent 1px),radial-gradient(circle at 40% 75%, rgba(255,255,255,.25) 0 1px, transparent 1px);background-size:130px 130px,170px 170px,210px 210px;z-index:1}
.vignette{inset:0;pointer-events:none;z-index:2;background:radial-gradient(circle at 50% 50%, transparent 0 38%, rgba(0,0,0,.42) 72%, rgba(0,0,0,.88) 100%),linear-gradient(to bottom, rgba(255,255,255,.04), rgba(0,0,0,.18))}
.hud{inset:0;z-index:5;display:grid;place-items:center;pointer-events:none;padding:24px}
.composer{--burst-x:50%;--burst-y:50%;width:min(780px,calc(100vw - 32px));padding:34px;border-radius:34px;background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.02)),var(--panel);backdrop-filter:blur(22px) saturate(110%);-webkit-backdrop-filter:blur(22px) saturate(110%);box-shadow:0 36px 100px rgba(0,0,0,.66), inset 0 1px 0 rgba(255,255,255,.12),0 0 80px rgba(255,255,255,.04);text-align:center;pointer-events:auto;position:relative;overflow:hidden;isolation:isolate;transform:translateY(-1.2vh) scale(1);opacity:1;clip-path:inset(0 round 34px);transition:opacity .9s ease, transform .9s cubic-bezier(.2,.9,.18,1), filter .9s ease;will-change:clip-path, filter, transform, opacity}
.composer>*{position:relative;z-index:2}
.composer::before,.composer::after{content:"";position:absolute;pointer-events:none;z-index:3;opacity:0}
.composer::before{left:var(--burst-x);top:var(--burst-y);width:18px;height:18px;border-radius:50%;transform:translate(-50%,-50%) scale(.2);background:radial-gradient(circle, rgba(255,255,255,.18), rgba(255,255,255,.08) 44%, rgba(255,255,255,0) 74%);filter:blur(1px)}
.composer::after{inset:0;background:radial-gradient(circle at var(--burst-x) var(--burst-y), rgba(255,255,255,.11), transparent 14%),radial-gradient(circle at var(--burst-x) var(--burst-y), rgba(255,255,255,.06), transparent 28%);transform-origin:var(--burst-x) var(--burst-y)}
.composer.sending{animation:panelSink 1.7s cubic-bezier(.22,.84,.18,1) forwards}
.composer.sending::before{opacity:1;animation:vortexCore 1.7s cubic-bezier(.22,.84,.18,1) forwards}
.composer.sending::after{opacity:1;animation:vortexWave 1.7s cubic-bezier(.22,.84,.18,1) forwards}
.composer.sending>*{animation:contentSpiral 1.7s cubic-bezier(.22,.84,.18,1) forwards}
.composer.hide{opacity:0;transform:translateY(-24px) scale(.97);filter:blur(14px);pointer-events:none}
@keyframes panelSink{0%{clip-path:inset(0 round 34px);opacity:1;filter:blur(0);transform:translateY(-1.2vh) scale(1)}24%{clip-path:circle(94% at var(--burst-x) var(--burst-y));opacity:1;filter:blur(0);transform:translateY(-1vh) scale(.992)}52%{clip-path:circle(58% at var(--burst-x) var(--burst-y));opacity:.98;filter:blur(.6px);transform:translateY(-.55vh) scale(.86)}76%{clip-path:circle(22% at var(--burst-x) var(--burst-y));opacity:.76;filter:blur(2.8px);transform:translateY(-.15vh) scale(.48)}100%{clip-path:circle(0% at var(--burst-x) var(--burst-y));opacity:0;filter:blur(8px);transform:translateY(0) scale(.16)}}
@keyframes vortexCore{0%{transform:translate(-50%,-50%) scale(.18);opacity:0}32%{transform:translate(-50%,-50%) scale(.7);opacity:.12}68%{transform:translate(-50%,-50%) scale(1.75);opacity:.34}100%{transform:translate(-50%,-50%) scale(2.65);opacity:.2}}
@keyframes vortexWave{0%{transform:scale(1) rotate(0deg);opacity:0}30%{transform:scale(1.01) rotate(1deg);opacity:.08}68%{transform:scale(.82) rotate(8deg);opacity:.2}100%{transform:scale(.28) rotate(16deg);opacity:0}}
@keyframes contentSpiral{0%{transform:translate3d(0,0,0) scale(1);opacity:1;filter:blur(0)}30%{transform:scale(.985);opacity:.98;filter:blur(0)}62%{transform:scale(.78) skewX(-1.4deg);opacity:.64;filter:blur(1.8px)}84%{transform:scale(.43) skewX(-3.2deg);opacity:.24;filter:blur(4.8px)}100%{transform:scale(.12) skewX(6deg);opacity:0;filter:blur(10px)}}
.kicker{margin-bottom:10px;color:rgba(255,255,255,.46);font-size:12px;letter-spacing:.2em;text-transform:uppercase}
h1{margin:0 0 12px;font-size:clamp(38px,5.6vw,72px);line-height:1;letter-spacing:.025em;font-weight:840;color:#fff;text-transform:uppercase;text-shadow:0 14px 70px rgba(255,255,255,.12);white-space:nowrap}
.subtitle{margin:0 auto 24px;max-width:100%;color:var(--muted);font-size:16px;line-height:1.4;letter-spacing:.005em;white-space:nowrap}
.emotion-row{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin:0 auto 18px}
.emotion{appearance:none;border:0;outline:0;color:#fff;padding:10px 14px;border-radius:999px;font-size:14px;font-weight:800;cursor:pointer;transition:transform .18s ease, box-shadow .18s ease, filter .18s ease;background:var(--emotion-button,#fff);box-shadow:0 8px 24px rgba(0,0,0,.25);text-transform:uppercase;letter-spacing:.02em}
.emotion[data-color="#FFD400"]{--emotion-button:#FFD400}.emotion[data-color="#4169E1"]{--emotion-button:#4169E1}.emotion[data-color="#8A2BE2"]{--emotion-button:#8A2BE2}.emotion[data-color="#FF2E2E"]{--emotion-button:#FF2E2E}.emotion[data-color="#FF8A00"]{--emotion-button:#FF8A00}.emotion[data-color="#22C55E"]{--emotion-button:#22C55E}
.emotion:hover{transform:translateY(-1px);filter:brightness(1.03)}
.emotion.active{transform:scale(1.06);box-shadow:0 0 22px var(--emotion-soft), 0 8px 24px rgba(0,0,0,.25)}
.input-shell{position:relative;display:grid;grid-template-columns:1fr auto;gap:12px;align-items:stretch;width:min(650px,100%);margin:0 auto;padding:9px;border-radius:24px;background:var(--emotion-mid);box-shadow:0 0 40px var(--emotion-soft);transition:background .25s ease, box-shadow .25s ease}
textarea{resize:none;height:78px;border:0;outline:0;color:#fff;background:transparent;padding:16px 16px 12px;font-size:21px;line-height:1.35;font-weight:520;font-family:inherit;letter-spacing:.01em}
textarea::placeholder{color:rgba(255,255,255,.74);letter-spacing:.01em}
.send{min-width:132px;border:0;border-radius:18px;background:rgb(255,255,255);color:var(--emotion);font-size:18px;font-weight:900;cursor:pointer;position:relative;overflow:hidden;transition:transform .18s ease, filter .18s ease, opacity .18s ease;box-shadow:0 12px 26px rgba(0,0,0,.38);text-transform:uppercase;letter-spacing:.03em;will-change:transform}
.send:hover{transform:translateY(-1px);filter:brightness(1.01)}
.send:disabled{opacity:.48;cursor:not-allowed;transform:none}
.meta{display:flex;justify-content:space-between;align-items:center;gap:12px;width:min(650px,100%);margin:13px auto 0;color:rgba(255,255,255,.52);font-size:13px;letter-spacing:.01em}
.warn{color:rgba(255,203,120,.92)}
.result{left:50%;top:28px;transform:translateX(-50%) translateY(-18px);z-index:6;width:min(700px,calc(100vw - 28px));opacity:0;pointer-events:none;transition:opacity .7s ease .18s, transform .7s cubic-bezier(.2,.9,.18,1) .18s}.result.show{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}
.result-card{border-radius:24px;background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.02)),var(--panel);box-shadow:0 36px 100px rgba(0,0,0,.66), inset 0 1px 0 rgba(255,255,255,.12),0 0 80px rgba(255,255,255,.04);backdrop-filter:blur(22px) saturate(110%);-webkit-backdrop-filter:blur(22px) saturate(110%);padding:18px 20px;display:grid;grid-template-columns:1fr auto;gap:16px;align-items:center}.result h2{margin:0 0 6px;font-size:20px;letter-spacing:-.01em}.result p{margin:0;color:rgba(255,255,255,.62);line-height:1.55;font-size:14px}.result strong{color:var(--emotion)}.actions{display:flex;flex-direction:column;gap:10px;justify-content:center;align-items:stretch;min-width:182px}
.ghost{appearance:none;border:0;border-radius:999px;background:rgba(255,255,255,.08);color:rgba(255,255,255,.86);padding:12px 14px;font-size:12px;font-weight:800;cursor:pointer;text-transform:uppercase;letter-spacing:.03em}.ghost:hover{background:rgba(255,255,255,.12)}
.star-message{left:50%;top:50%;transform:translate(-50%,-50%) scale(.95);z-index:9;width:min(360px,calc(100vw - 28px));padding:18px 18px 16px;border-radius:22px;background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.02)),var(--panel);backdrop-filter:blur(22px) saturate(110%);-webkit-backdrop-filter:blur(22px) saturate(110%);box-shadow:0 26px 80px rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:opacity .28s ease, transform .28s ease}.star-message.show{opacity:1;pointer-events:auto;transform:translate(-50%,-50%) scale(1)}
.star-message-close{position:absolute;right:12px;top:10px;appearance:none;border:0;background:transparent;color:rgba(255,255,255,.64);font-size:24px;cursor:pointer}.star-message-label{display:inline-flex;padding:6px 10px;border-radius:999px;background:var(--emotion-mid);color:#fff;font-size:12px;font-weight:700;margin-bottom:12px}.star-message-text{font-size:22px;line-height:1.32;font-weight:650;margin-bottom:10px;letter-spacing:.01em}.star-message-meta{color:rgba(255,255,255,.56);font-size:13px}
.country-tooltip{left:0;top:0;transform:translate(-9999px,-9999px);z-index:8;padding:8px 10px;border-radius:999px;background:rgba(0,0,0,.82);color:#fff;font-size:12px;letter-spacing:.02em;pointer-events:none;white-space:nowrap;box-shadow:0 14px 30px rgba(0,0,0,.35)}
.launch-star{left:0;top:0;z-index:8;pointer-events:none;opacity:0;width:110px;height:110px;transform:translate(-9999px,-9999px);will-change:transform,opacity}
.launch-core,.launch-glow,.launch-tail{position:absolute}
.launch-core{left:41px;top:41px;width:28px;height:28px;border-radius:50%;background:radial-gradient(circle at 34% 34%, #fff 0 16%, var(--emotion) 42%, rgba(255,255,255,.96) 66%, rgba(255,255,255,0) 100%);box-shadow:0 0 18px #fff, 0 0 48px var(--emotion), 0 0 88px var(--emotion-soft)}
.launch-glow{left:22px;top:22px;width:66px;height:66px;border-radius:50%;background:radial-gradient(circle, rgba(255,255,255,.45), transparent 72%);filter:blur(10px)}
.launch-tail{left:-8px;top:50px;width:78px;height:12px;border-radius:999px;background:linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,.18), rgba(255,255,255,.82));filter:blur(8px);opacity:var(--tail-opacity,0)}
.loading{left:50%;top:24px;transform:translateX(-50%);z-index:7;padding:10px 14px;border-radius:999px;background:rgba(8,8,8,.7);font-size:13px;opacity:1;transition:opacity .35s ease}.loading.hide{opacity:0;pointer-events:none}
.hint{right:18px;bottom:16px;z-index:6;color:rgba(255,255,255,.44);font-size:12px;letter-spacing:.06em}
.rotation-info{left:18px;bottom:16px;z-index:6;color:rgba(255,255,255,.44);font-size:12px;letter-spacing:.04em}
.toast{left:50%;bottom:28px;transform:translateX(-50%) translateY(20px);opacity:0;z-index:10;padding:12px 16px;border-radius:999px;color:rgba(255,255,255,.88);background:rgba(5,10,20,.74);backdrop-filter:blur(14px);transition:opacity .3s ease, transform .3s ease;pointer-events:none;font-size:14px}.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
@media (max-width:700px){.composer{padding:24px 18px;border-radius:28px}.input-shell{grid-template-columns:1fr}textarea{height:88px;font-size:19px}.send{height:58px;width:100%}.result-card{grid-template-columns:1fr}.actions{justify-content:flex-start;min-width:0}.subtitle{font-size:14px}h1{font-size:clamp(32px,8vw,54px)}}

/* v9 stability and polish overrides */
.kicker,.subtitle,.meta{color:var(--emotion);text-shadow:0 0 22px var(--emotion-soft)}
.emotion{font-weight:520;color:#fff;border:0;outline:0;box-shadow:0 8px 22px rgba(0,0,0,.22)}
.emotion.active{transform:scale(1.045);box-shadow:0 0 18px var(--emotion-soft),0 8px 22px rgba(0,0,0,.22)}
.launch-star{width:86px;height:86px}
.launch-core{left:33px;top:33px;width:20px;height:20px;background:radial-gradient(circle, var(--emotion) 0 62%, rgba(255,255,255,0) 100%);box-shadow:0 0 16px var(--emotion),0 0 32px var(--emotion-soft)}
.launch-glow{left:22px;top:22px;width:42px;height:42px;background:radial-gradient(circle, var(--emotion-soft), transparent 72%);filter:blur(8px);opacity:.55}
.launch-tail{left:-4px;top:38px;width:58px;height:8px;background:linear-gradient(90deg, rgba(255,255,255,0), var(--emotion));filter:blur(7px)}
.result.show .result-card{animation:confirmPulse .95s cubic-bezier(.2,.9,.18,1) both}
@keyframes confirmPulse{0%{box-shadow:0 36px 100px rgba(0,0,0,.66),0 0 0 var(--emotion-soft);transform:translateY(-4px) scale(.985)}45%{box-shadow:0 36px 100px rgba(0,0,0,.66),0 0 44px var(--emotion-soft);transform:translateY(0) scale(1.01)}100%{box-shadow:0 36px 100px rgba(0,0,0,.66),0 0 18px rgba(255,255,255,.04);transform:translateY(0) scale(1)}}
.rotation-info{color:rgba(255,255,255,.5)}
.fallback-mode .loading::after{content:' · SAFE MODE';opacity:.6}


/* v10 requested refinements */
:root{--ui-gray:rgba(255,255,255,.54);--ui-gray-strong:rgba(255,255,255,.62);}
.kicker,.subtitle,.meta,#counter{color:var(--ui-gray)!important;text-shadow:none!important;}
.meta{justify-content:flex-start!important;text-align:left!important;}
.emotion-meta-hidden{display:none!important;}
.hint{display:none!important;}
.emotion{font-weight:680!important;color:#fff!important;text-shadow:0 1px 8px rgba(0,0,0,.18);}
.emotion.active{transform:scale(1.035)!important;box-shadow:0 9px 24px rgba(0,0,0,.24)!important;}
.composer.sending{animation:panelSink 1.32s cubic-bezier(.16,.92,.16,1) forwards!important;}
.composer.sending::before{animation:vortexCore 1.32s cubic-bezier(.16,.92,.16,1) forwards!important;}
.composer.sending::after{animation:vortexWave 1.32s cubic-bezier(.16,.92,.16,1) forwards!important;}
.composer.sending>*{animation:contentSpiral 1.32s cubic-bezier(.16,.92,.16,1) forwards!important;}
@keyframes panelSink{0%{clip-path:inset(0 round 34px);opacity:1;filter:blur(0);transform:translateY(-1.2vh) scale(1)}16%{clip-path:circle(98% at var(--burst-x) var(--burst-y));opacity:1;filter:blur(0);transform:translateY(-1vh) scale(.995)}39%{clip-path:circle(71% at var(--burst-x) var(--burst-y));opacity:.98;filter:blur(.35px);transform:translateY(-.72vh) scale(.93)}63%{clip-path:circle(36% at var(--burst-x) var(--burst-y));opacity:.86;filter:blur(1.7px);transform:translateY(-.32vh) scale(.66)}82%{clip-path:circle(12% at var(--burst-x) var(--burst-y));opacity:.46;filter:blur(4.2px);transform:translateY(-.08vh) scale(.34)}100%{clip-path:circle(0% at var(--burst-x) var(--burst-y));opacity:0;filter:blur(9px);transform:translateY(0) scale(.12)}}
@keyframes vortexCore{0%{transform:translate(-50%,-50%) scale(.12);opacity:0}22%{transform:translate(-50%,-50%) scale(.58);opacity:.12}54%{transform:translate(-50%,-50%) scale(1.38);opacity:.28}82%{transform:translate(-50%,-50%) scale(2.28);opacity:.24}100%{transform:translate(-50%,-50%) scale(2.9);opacity:.08}}
@keyframes vortexWave{0%{transform:scale(1) rotate(0deg);opacity:0}24%{transform:scale(.995) rotate(2deg);opacity:.07}58%{transform:scale(.78) rotate(9deg);opacity:.18}100%{transform:scale(.18) rotate(22deg);opacity:0}}
@keyframes contentSpiral{0%{transform:translate3d(0,0,0) scale(1);opacity:1;filter:blur(0)}22%{transform:scale(.975) skewX(.15deg);opacity:.96;filter:blur(.08px)}50%{transform:scale(.82) skewX(-.8deg);opacity:.72;filter:blur(1.2px)}76%{transform:scale(.46) skewX(-2.6deg);opacity:.32;filter:blur(4px)}100%{transform:scale(.1) skewX(5deg);opacity:0;filter:blur(10px)}}
.launch-core{background:var(--emotion)!important;box-shadow:0 0 10px var(--emotion),0 0 20px var(--emotion-soft)!important;}
.launch-glow{background:radial-gradient(circle, var(--emotion-soft), transparent 74%)!important;opacity:.42!important;}
.launch-tail{background:linear-gradient(90deg, rgba(255,255,255,0), var(--emotion))!important;opacity:var(--tail-opacity,0)!important;}
.warn{color:var(--ui-gray-strong)!important;}

/* v11 performance / one-pass send animation overrides */
:root{--emotion-bright:#ffe34f;}
.grain{opacity:.045;}
.kicker,.subtitle,.meta,#counter{color:var(--ui-gray)!important;text-shadow:none!important;}
.emotion{font-weight:720!important;}
.composer.sending,.composer.sending::before,.composer.sending::after,.composer.sending>*{animation:none!important;}
.composer.js-sending{transition:none!important;will-change:transform,opacity,filter,clip-path;}
.composer.js-sending::before,.composer.js-sending::after{display:none!important;}
.composer.hide{pointer-events:none;}
.launch-star{width:92px;height:92px;will-change:transform,opacity;}
.launch-core{left:35px;top:35px;width:22px;height:22px;background:radial-gradient(circle, var(--emotion-bright) 0 58%, var(--emotion) 66%, rgba(255,255,255,0) 100%)!important;box-shadow:0 0 10px var(--emotion-bright),0 0 22px var(--emotion),0 0 40px var(--emotion-soft)!important;}
.launch-glow{left:24px;top:24px;width:44px;height:44px;background:radial-gradient(circle, var(--emotion-bright), transparent 74%)!important;filter:blur(7px)!important;opacity:.46!important;}
.launch-tail{left:-4px;top:41px;width:60px;height:8px;filter:blur(6px)!important;background:linear-gradient(90deg, rgba(255,255,255,0), var(--emotion-bright))!important;}
.rotation-info{color:rgba(255,255,255,.48)}
@media (prefers-reduced-motion: reduce){
  .composer,.result,.toast,.star-message{transition:none!important;}
}

/* v12 color inversion, faster UI and 20-character counter */
html,body,#app,.composer,.result-card,.star-message,.invert-toggle,.send,.ghost{transition:background-color .42s ease,color .42s ease,border-color .42s ease,box-shadow .42s ease,filter .42s ease;}
.invert-toggle{position:fixed;left:18px;top:18px;z-index:11;appearance:none;border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:10px 13px;background:rgba(8,8,8,.54);color:rgba(255,255,255,.7);font-size:11px;font-weight:800;letter-spacing:.08em;cursor:pointer;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 14px 36px rgba(0,0,0,.28);}
.invert-toggle:hover{color:#fff;background:rgba(20,20,20,.7);transform:translateY(-1px);}
.invert-toggle[aria-pressed="true"]{border-color:rgba(0,0,0,.16);background:rgba(255,255,255,.64);color:rgba(0,0,0,.72);box-shadow:0 14px 36px rgba(255,255,255,.18);}
body.inverted{--bg:#f6f6f6;--panel:rgba(245,245,245,.62);--text:rgba(0,0,0,.92);--muted:rgba(0,0,0,.58);--ui-gray:rgba(0,0,0,.56);--ui-gray-strong:rgba(0,0,0,.66);background:#f6f6f6;color:var(--text);}
body.inverted #app{background:radial-gradient(circle at 50% 46%, rgba(0,0,0,.045), transparent 33%),radial-gradient(circle at 50% 58%, rgba(0,0,0,.035), transparent 54%),#f6f6f6;}
body.inverted .grain{opacity:.025;mix-blend-mode:multiply;filter:invert(1);}
body.inverted .vignette{background:radial-gradient(circle at 50% 50%, transparent 0 40%, rgba(255,255,255,.1) 72%, rgba(255,255,255,.42) 100%),linear-gradient(to bottom, rgba(0,0,0,.035), rgba(255,255,255,.16));}
body.inverted .composer,body.inverted .result-card,body.inverted .star-message{background:linear-gradient(180deg, rgba(0,0,0,.045), rgba(0,0,0,.015)),var(--panel);box-shadow:0 36px 100px rgba(255,255,255,.35), inset 0 1px 0 rgba(0,0,0,.08),0 0 80px rgba(0,0,0,.035);}
body.inverted h1{color:#050505;text-shadow:0 14px 70px rgba(0,0,0,.08);}
body.inverted .send{background:#050505;color:var(--emotion-bright);}
body.inverted .ghost{background:rgba(0,0,0,.075);color:rgba(0,0,0,.76);}
body.inverted .country-tooltip{background:rgba(255,255,255,.86);color:#050505;box-shadow:0 14px 30px rgba(255,255,255,.35);}
body.inverted .loading,body.inverted .toast{background:rgba(255,255,255,.76);color:rgba(0,0,0,.82);}
body.inverted .star-message-close{color:rgba(0,0,0,.56);}
body.inverted .star-message-text{color:rgba(0,0,0,.9);}
body.inverted .star-message-meta{color:rgba(0,0,0,.56);}
#counter{min-width:128px;}
.composer.js-sending{transition:none!important;}
.composer.js-sending *{transition:none!important;}


/* v13 switch clarity and timing refinements */
.invert-toggle{letter-spacing:.08em;}
body.switching #earthCanvas{transition:opacity .18s ease, filter .18s ease;opacity:.985;}
.launch-star{width:96px;height:96px;}
.launch-core{left:34px!important;top:34px!important;width:28px!important;height:28px!important;box-shadow:0 0 12px var(--emotion-bright),0 0 28px var(--emotion),0 0 48px var(--emotion-soft)!important;}
.launch-glow{left:22px!important;top:22px!important;width:52px!important;height:52px!important;filter:blur(7px)!important;opacity:.48!important;}
.launch-tail{top:44px!important;width:66px!important;}


/* v14 default white version + calibrate button + white-mode text fixes */
.top-tools{
  position:fixed;
  left:18px;
  top:18px;
  z-index:11;
  display:flex;
  flex-direction:column;
  gap:8px;
  align-items:flex-start;
}
.top-tools .invert-toggle,
.top-tools .calibrate-toggle{
  position:static!important;
  left:auto!important;
  top:auto!important;
}
.calibrate-toggle{
  appearance:none;
  border:1px solid rgba(255,255,255,.16);
  border-radius:999px;
  padding:10px 13px;
  background:rgba(8,8,8,.54);
  color:rgba(255,255,255,.7);
  font-size:11px;
  font-weight:800;
  letter-spacing:.08em;
  cursor:pointer;
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  box-shadow:0 14px 36px rgba(0,0,0,.28);
  transition:background-color .42s ease,color .42s ease,border-color .42s ease,box-shadow .42s ease,transform .18s ease;
}
.calibrate-toggle:hover{
  color:#fff;
  background:rgba(20,20,20,.7);
  transform:translateY(-1px);
}
body.inverted .calibrate-toggle,
body.inverted .invert-toggle{
  border-color:rgba(0,0,0,.16);
  background:rgba(255,255,255,.68);
  color:rgba(0,0,0,.76);
  box-shadow:0 14px 36px rgba(255,255,255,.18);
}
body.inverted .calibrate-toggle:hover,
body.inverted .invert-toggle:hover{
  background:rgba(255,255,255,.86);
  color:#000;
}
body.inverted textarea{
  color:#050505!important;
}
body.inverted textarea::placeholder{
  color:rgba(0,0,0,.48)!important;
}
body.inverted .input-shell{
  color:#050505;
}
body.inverted .result h2,
body.inverted .result p,
body.inverted .result strong,
body.inverted #sentEmotionInline{
  color:rgba(0,0,0,.86)!important;
}
body.inverted .result p{
  color:rgba(0,0,0,.62)!important;
}
body.inverted .result strong,
body.inverted #sentEmotionInline{
  color:var(--emotion)!important;
}
body.inverted .rotation-info{
  color:rgba(0,0,0,.46)!important;
}
body.inverted .hint{
  color:rgba(0,0,0,.38)!important;
}


/* v16 Changsha north-up entry view + country-locked sending */
.location-meta{
  display:inline-flex!important;
  align-items:center;
  min-height:1.2em;
  color:var(--ui-gray)!important;
  font-size:13px;
  letter-spacing:.01em;
}
.location-meta.warn{
  color:var(--ui-gray-strong)!important;
}
.meta{
  justify-content:space-between!important;
}
body.inverted .location-meta{
  color:rgba(0,0,0,.56)!important;
}
body.inverted .location-meta.warn{
  color:rgba(0,0,0,.68)!important;
}


/* v17 Daily Echo retention layer */
.daily-question{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  max-width:min(650px,100%);
  margin:0 auto 22px;
  padding:9px 13px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  background:rgba(255,255,255,.055);
  color:rgba(255,255,255,.68);
  font-size:13px;
  line-height:1.35;
  letter-spacing:.01em;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}
.daily-label,
.echo-label,
.mood-title{
  font-size:10px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--emotion);
  white-space:nowrap;
}
.result-card{
  align-items:start;
}
.daily-echo{
  grid-column:1 / -1;
  display:grid;
  gap:10px;
  padding-top:14px;
  margin-top:2px;
  border-top:1px solid rgba(255,255,255,.12);
}
.daily-echo blockquote{
  margin:0;
  color:rgba(255,255,255,.93);
  font-size:20px;
  line-height:1.35;
  font-weight:740;
  letter-spacing:.005em;
}
.echo-meta{
  color:rgba(255,255,255,.56);
  font-size:13px;
}
.world-mood{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px;
  margin-top:2px;
}
.mood-pill{
  display:inline-flex;
  align-items:center;
  padding:6px 9px;
  border-radius:999px;
  background:color-mix(in srgb, var(--mood-color) 20%, transparent);
  border:1px solid color-mix(in srgb, var(--mood-color) 34%, transparent);
  color:rgba(255,255,255,.76);
  font-size:12px;
  font-weight:760;
}
.daily-streak{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:9px;
  color:rgba(255,255,255,.56);
  font-size:12px;
  margin-top:1px;
}
.streak-dots{
  display:inline-flex;
  gap:5px;
  align-items:center;
}
.streak-dots i{
  width:7px;
  height:7px;
  border-radius:50%;
  display:block;
  background:rgba(255,255,255,.18);
  box-shadow:0 0 0 rgba(255,255,255,0);
}
.streak-dots i.filled{
  background:var(--emotion);
  box-shadow:0 0 12px var(--emotion-soft);
}
body.inverted .daily-question{
  background:rgba(0,0,0,.045);
  border-color:rgba(0,0,0,.12);
  color:rgba(0,0,0,.62);
}
body.inverted .daily-echo{
  border-top-color:rgba(0,0,0,.12);
}
body.inverted .daily-echo blockquote{
  color:rgba(0,0,0,.88);
}
body.inverted .echo-meta,
body.inverted .daily-streak{
  color:rgba(0,0,0,.56);
}
body.inverted .mood-pill{
  background:color-mix(in srgb, var(--mood-color) 16%, transparent);
  border-color:color-mix(in srgb, var(--mood-color) 28%, transparent);
  color:rgba(0,0,0,.68);
}
body.inverted .streak-dots i{
  background:rgba(0,0,0,.16);
}
body.inverted .streak-dots i.filled{
  background:var(--emotion);
}
@media (max-width:700px){
  .daily-question{display:flex;flex-direction:column;gap:5px;border-radius:18px;margin-bottom:16px;padding:10px 12px;}
  .daily-echo blockquote{font-size:18px;}
  .world-mood{gap:6px;}
  .mood-pill{font-size:11px;padding:5px 8px;}
}

/* v18 text cleanup, Beijing clock, smoother UI and clearer Earth */
.composer{padding-top:30px;backdrop-filter:blur(16px) saturate(108%);-webkit-backdrop-filter:blur(16px) saturate(108%);}
.result-card,.star-message{backdrop-filter:blur(16px) saturate(108%);-webkit-backdrop-filter:blur(16px) saturate(108%);}
.emotion-wrap{display:flex;align-items:center;justify-content:center;gap:14px;width:min(650px,100%);margin:0 auto 18px;}
.emotion-wrap .emotion-row{margin:0;flex:1 1 auto;justify-content:center;}
.emotion-guide{margin:0;max-width:210px;color:var(--ui-gray, rgba(255,255,255,.56));font-size:14px;line-height:1.28;font-weight:650;text-align:left;letter-spacing:.005em;}
body.inverted .emotion-guide{color:rgba(0,0,0,.58);}
.daily-question{font-size:15px;padding:10px 15px;margin-bottom:20px;}
#dailyPrompt{font-size:15px;font-weight:720;}
.daily-label,.echo-label,.mood-title{font-size:11px;letter-spacing:.15em;}
.echo-label{font-size:12px;}
.daily-echo{gap:11px;}
.daily-echo blockquote{font-size:22px;line-height:1.34;}
.echo-meta{font-size:14px;}
.mood-title{font-size:12px;margin-right:2px;}
.mood-pill{font-size:13px;padding:7px 10px;}
.daily-streak{font-size:13px;}
.actions{min-width:148px;}
.beijing-clock{position:fixed;right:18px;bottom:18px;z-index:7;padding:10px 12px;border-radius:999px;background:rgba(8,8,8,.44);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.58);font-size:11px;font-weight:800;letter-spacing:.08em;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);pointer-events:none;white-space:nowrap;}
body.inverted .beijing-clock{background:rgba(255,255,255,.66);border-color:rgba(0,0,0,.12);color:rgba(0,0,0,.56);}
#earthCanvas{image-rendering:auto;}
@media (max-width:700px){
  .emotion-wrap{flex-direction:column;gap:10px;margin-bottom:16px;}
  .emotion-guide{max-width:100%;text-align:center;font-size:13px;}
  .daily-question{font-size:14px;}
  #dailyPrompt{font-size:14px;}
  .daily-echo blockquote{font-size:20px;}
  .beijing-clock{right:12px;bottom:12px;font-size:10px;max-width:calc(100vw - 24px);white-space:normal;text-align:right;}
}

/* v19 single-line mood controls + real-star echo data */
.emotion-wrap{
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:center!important;
  gap:10px!important;
  width:min(650px,100%)!important;
  margin:0 auto 18px!important;
}
.emotion-guide{
  order:0!important;
  width:100%!important;
  max-width:none!important;
  margin:0!important;
  text-align:center!important;
  white-space:nowrap!important;
  color:var(--ui-gray, rgba(255,255,255,.56))!important;
  font-size:14px!important;
  line-height:1.2!important;
  font-weight:700!important;
}
.emotion-wrap .emotion-row,
.emotion-row{
  order:1!important;
  width:100%!important;
  display:flex!important;
  flex-wrap:nowrap!important;
  justify-content:center!important;
  align-items:center!important;
  gap:10px!important;
  margin:0 auto!important;
  overflow-x:auto!important;
  overflow-y:hidden!important;
  scrollbar-width:none!important;
  -webkit-overflow-scrolling:touch!important;
  padding:2px 2px 8px!important;
}
.emotion-wrap .emotion-row::-webkit-scrollbar,
.emotion-row::-webkit-scrollbar{display:none!important;}
.emotion-row .emotion{
  flex:0 0 auto!important;
  white-space:nowrap!important;
}
.mood-empty{
  color:rgba(255,255,255,.56);
  font-size:13px;
  font-weight:720;
}
body.inverted .mood-empty{color:rgba(0,0,0,.56);}
@media (max-width:700px){
  .emotion-wrap{align-items:stretch!important;}
  .emotion-guide{font-size:12px!important;letter-spacing:-.01em!important;}
  .emotion-wrap .emotion-row,
  .emotion-row{justify-content:flex-start!important;padding-inline:2px!important;}
  .emotion{padding:9px 12px!important;font-size:12px!important;}
}
@media (max-width:380px){
  .emotion-guide{font-size:11px!important;}
  .emotion{padding:8px 10px!important;font-size:11px!important;}
}
