:root{--color-white:#fff;--color-black:#000;--color-cream-50:#fcfcf9;--color-cream-100:#fffffd;--color-gray-200:#f5f5f5;--color-gray-300:#a7a9a9;--color-gray-400:#777c7c;--color-slate-500:#626c71;--color-brown-600:#5e5240;--color-charcoal-700:#1f2121;--color-charcoal-800:#262828;--color-slate-900:#13343b;--color-teal-300:#32b8c6;--color-teal-400:#2da6b2;--color-teal-500:#21808d;--color-teal-600:#1d7480;--color-teal-700:#1a6873;--color-teal-800:#2996a1;--color-red-400:#ff5459;--color-red-500:#c0152f;--color-orange-400:#e68161;--color-orange-500:#a84b2f;--color-brown-600-rgb:94,82,64;--color-teal-500-rgb:33,128,141;--color-slate-900-rgb:19,52,59;--color-slate-500-rgb:98,108,113;--color-red-500-rgb:192,21,47;--color-red-400-rgb:255,84,89;--color-orange-500-rgb:168,75,47;--color-orange-400-rgb:230,129,97;--color-bg-1:#3b82f614;--color-bg-2:#f59e0b14;--color-bg-3:#22c55e14;--color-bg-4:#ef444414;--color-bg-5:#9333ea14;--color-bg-6:#f9731614;--color-bg-7:#ec489914;--color-bg-8:#06b6d414;--color-background:var(--color-cream-50);--color-surface:var(--color-cream-100);--color-text:var(--color-slate-900);--color-text-secondary:var(--color-slate-500);--color-primary:var(--color-teal-500);--color-primary-hover:var(--color-teal-600);--color-primary-active:var(--color-teal-700);--color-secondary:rgba(var(--color-brown-600-rgb),.12);--color-secondary-hover:rgba(var(--color-brown-600-rgb),.2);--color-secondary-active:rgba(var(--color-brown-600-rgb),.25);--color-border:rgba(var(--color-brown-600-rgb),.2);--color-btn-primary-text:var(--color-cream-50);--color-card-border:rgba(var(--color-brown-600-rgb),.12);--color-card-border-inner:rgba(var(--color-brown-600-rgb),.12);--color-error:var(--color-red-500);--color-success:var(--color-teal-500);--color-warning:var(--color-orange-500);--color-info:var(--color-slate-500);--color-focus-ring:rgba(var(--color-teal-500-rgb),.4);--color-select-caret:rgba(var(--color-slate-900-rgb),.8);--focus-ring:0 0 0 3px var(--color-focus-ring);--focus-outline:2px solid var(--color-primary);--status-bg-opacity:.15;--status-border-opacity:.25;--select-caret-light:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23134252' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");--select-caret-dark:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23f5f5f5' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");--color-success-rgb:33,128,141;--color-error-rgb:192,21,47;--color-warning-rgb:168,75,47;--color-info-rgb:98,108,113;--font-family-base:"FKGroteskNeue","Geist","Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-family-mono:"Berkeley Mono",ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;--font-size-xs:11px;--font-size-sm:12px;--font-size-base:14px;--font-size-md:14px;--font-size-lg:16px;--font-size-xl:18px;--font-size-2xl:20px;--font-size-3xl:24px;--font-size-4xl:30px;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:550;--font-weight-bold:600;--line-height-tight:1.2;--line-height-normal:1.5;--letter-spacing-tight:-.01em;--space-0:0;--space-1:1px;--space-2:2px;--space-4:4px;--space-6:6px;--space-8:8px;--space-10:10px;--space-12:12px;--space-16:16px;--space-20:20px;--space-24:24px;--space-32:32px;--radius-sm:6px;--radius-base:8px;--radius-md:10px;--radius-lg:12px;--radius-full:9999px;--shadow-xs:0 1px 2px #00000005;--shadow-sm:0 1px 3px #0000000a,0 1px 2px #00000005;--shadow-md:0 4px 6px -1px #0000000a,0 2px 4px -1px #00000005;--shadow-lg:0 10px 15px -3px #0000000a,0 4px 6px -2px #00000005;--shadow-inset-sm:inset 0 1px 0 #ffffff26,inset 0 -1px 0 #00000008;--duration-fast:.15s;--duration-normal:.25s;--ease-standard:cubic-bezier(.16,1,.3,1);--container-sm:640px;--container-md:768px;--container-lg:1024px;--container-xl:1280px}@media (prefers-color-scheme:dark){:root{--color-gray-400-rgb:119,124,124;--color-teal-300-rgb:50,184,198;--color-gray-300-rgb:167,169,169;--color-gray-200-rgb:245,245,245;--color-bg-1:#1d4ed826;--color-bg-2:#b4530926;--color-bg-3:#15803d26;--color-bg-4:#b91c1c26;--color-bg-5:#6b21a826;--color-bg-6:#c2410c26;--color-bg-7:#be185d26;--color-bg-8:#0891b226;--color-background:var(--color-charcoal-700);--color-surface:var(--color-charcoal-800);--color-text:var(--color-gray-200);--color-text-secondary:rgba(var(--color-gray-300-rgb),.7);--color-primary:var(--color-teal-300);--color-primary-hover:var(--color-teal-400);--color-primary-active:var(--color-teal-800);--color-secondary:rgba(var(--color-gray-400-rgb),.15);--color-secondary-hover:rgba(var(--color-gray-400-rgb),.25);--color-secondary-active:rgba(var(--color-gray-400-rgb),.3);--color-border:rgba(var(--color-gray-400-rgb),.3);--color-error:var(--color-red-400);--color-success:var(--color-teal-300);--color-warning:var(--color-orange-400);--color-info:var(--color-gray-300);--color-focus-ring:rgba(var(--color-teal-300-rgb),.4);--color-btn-primary-text:var(--color-slate-900);--color-card-border:rgba(var(--color-gray-400-rgb),.2);--color-card-border-inner:rgba(var(--color-gray-400-rgb),.15);--shadow-inset-sm:inset 0 1px 0 #ffffff1a,inset 0 -1px 0 #00000026;--button-border-secondary:rgba(var(--color-gray-400-rgb),.2);--color-border-secondary:rgba(var(--color-gray-400-rgb),.2);--color-select-caret:rgba(var(--color-gray-200-rgb),.8);--focus-ring:0 0 0 3px var(--color-focus-ring);--focus-outline:2px solid var(--color-primary);--status-bg-opacity:.15;--status-border-opacity:.25;--select-caret-light:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23134252' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");--select-caret-dark:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23f5f5f5' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");--color-success-rgb:var(--color-teal-300-rgb);--color-error-rgb:var(--color-red-400-rgb);--color-warning-rgb:var(--color-orange-400-rgb);--color-info-rgb:var(--color-gray-300-rgb)}}[data-color-scheme=dark]{--color-gray-400-rgb:119,124,124;--color-teal-300-rgb:50,184,198;--color-gray-300-rgb:167,169,169;--color-gray-200-rgb:245,245,245;--color-bg-1:#1d4ed826;--color-bg-2:#b4530926;--color-bg-3:#15803d26;--color-bg-4:#b91c1c26;--color-bg-5:#6b21a826;--color-bg-6:#c2410c26;--color-bg-7:#be185d26;--color-bg-8:#0891b226;--color-background:var(--color-charcoal-700);--color-surface:var(--color-charcoal-800);--color-text:var(--color-gray-200);--color-text-secondary:rgba(var(--color-gray-300-rgb),.7);--color-primary:var(--color-teal-300);--color-primary-hover:var(--color-teal-400);--color-primary-active:var(--color-teal-800);--color-secondary:rgba(var(--color-gray-400-rgb),.15);--color-secondary-hover:rgba(var(--color-gray-400-rgb),.25);--color-secondary-active:rgba(var(--color-gray-400-rgb),.3);--color-border:rgba(var(--color-gray-400-rgb),.3);--color-error:var(--color-red-400);--color-success:var(--color-teal-300);--color-warning:var(--color-orange-400);--color-info:var(--color-gray-300);--color-focus-ring:rgba(var(--color-teal-300-rgb),.4);--color-btn-primary-text:var(--color-slate-900);--color-card-border:rgba(var(--color-gray-400-rgb),.15);--color-card-border-inner:rgba(var(--color-gray-400-rgb),.15);--shadow-inset-sm:inset 0 1px 0 #ffffff1a,inset 0 -1px 0 #00000026;--color-border-secondary:rgba(var(--color-gray-400-rgb),.2);--color-select-caret:rgba(var(--color-gray-200-rgb),.8);--focus-ring:0 0 0 3px var(--color-focus-ring);--focus-outline:2px solid var(--color-primary);--status-bg-opacity:.15;--status-border-opacity:.25;--select-caret-light:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23134252' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");--select-caret-dark:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23f5f5f5' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");--color-success-rgb:var(--color-teal-300-rgb);--color-error-rgb:var(--color-red-400-rgb);--color-warning-rgb:var(--color-orange-400-rgb);--color-info-rgb:var(--color-gray-300-rgb)}[data-color-scheme=light]{--color-brown-600-rgb:94,82,64;--color-teal-500-rgb:33,128,141;--color-slate-900-rgb:19,52,59;--color-background:var(--color-cream-50);--color-surface:var(--color-cream-100);--color-text:var(--color-slate-900);--color-text-secondary:var(--color-slate-500);--color-primary:var(--color-teal-500);--color-primary-hover:var(--color-teal-600);--color-primary-active:var(--color-teal-700);--color-secondary:rgba(var(--color-brown-600-rgb),.12);--color-secondary-hover:rgba(var(--color-brown-600-rgb),.2);--color-secondary-active:rgba(var(--color-brown-600-rgb),.25);--color-border:rgba(var(--color-brown-600-rgb),.2);--color-btn-primary-text:var(--color-cream-50);--color-card-border:rgba(var(--color-brown-600-rgb),.12);--color-card-border-inner:rgba(var(--color-brown-600-rgb),.12);--color-error:var(--color-red-500);--color-success:var(--color-teal-500);--color-warning:var(--color-orange-500);--color-info:var(--color-slate-500);--color-focus-ring:rgba(var(--color-teal-500-rgb),.4);--color-success-rgb:var(--color-teal-500-rgb);--color-error-rgb:var(--color-red-500-rgb);--color-warning-rgb:var(--color-orange-500-rgb);--color-info-rgb:var(--color-slate-500-rgb)}html{font-size:var(--font-size-base);font-family:var(--font-family-base);line-height:var(--line-height-normal);color:var(--color-text);background-color:var(--color-background);-webkit-font-smoothing:antialiased;box-sizing:border-box}body{margin:0;padding:0}*,:before,:after{box-sizing:inherit;-webkit-user-select:inherit;user-select:inherit}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);color:var(--color-text);letter-spacing:var(--letter-spacing-tight);margin:0}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-md)}p{margin:0 0 var(--space-16)0}a{color:var(--color-primary);transition:color var(--duration-fast)var(--ease-standard);text-decoration:none}a:hover{color:var(--color-primary-hover)}code,pre{font-family:var(--font-family-mono);font-size:calc(var(--font-size-base)*.95);background-color:var(--color-secondary);border-radius:var(--radius-sm)}code{padding:var(--space-1)var(--space-4)}pre{padding:var(--space-16);margin:var(--space-16)0;border:1px solid var(--color-border);overflow:auto}pre code{background:0 0;padding:0}.btn{padding:var(--space-8)var(--space-16);border-radius:var(--radius-base);font-size:var(--font-size-base);cursor:pointer;transition:all var(--duration-normal)var(--ease-standard);border:none;justify-content:center;align-items:center;font-weight:500;line-height:1.5;text-decoration:none;display:inline-flex;position:relative}.btn:focus-visible{box-shadow:var(--focus-ring);outline:none}.btn--primary{background:var(--color-primary);color:var(--color-btn-primary-text)}.btn--primary:hover{background:var(--color-primary-hover)}.btn--primary:active{background:var(--color-primary-active)}.btn--secondary{background:var(--color-secondary);color:var(--color-text)}.btn--secondary:hover{background:var(--color-secondary-hover)}.btn--secondary:active{background:var(--color-secondary-active)}.btn--outline{border:1px solid var(--color-border);color:var(--color-text);background:0 0}.btn--outline:hover{background:var(--color-secondary)}.btn--sm{padding:var(--space-4)var(--space-12);font-size:var(--font-size-sm);border-radius:var(--radius-sm)}.btn--lg{padding:var(--space-10)var(--space-20);font-size:var(--font-size-lg);border-radius:var(--radius-md)}.btn--full-width{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed}.form-control{width:100%;padding:var(--space-8)var(--space-12);font-size:var(--font-size-md);color:var(--color-text);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-base);transition:border-color var(--duration-fast)var(--ease-standard),box-shadow var(--duration-fast)var(--ease-standard);line-height:1.5;display:block}textarea.form-control{font-family:var(--font-family-base);font-size:var(--font-size-base)}select.form-control{padding:var(--space-8)var(--space-12);appearance:none;background-image:var(--select-caret-light);background-repeat:no-repeat;background-position:right var(--space-12)center;padding-right:var(--space-32);background-size:16px}@media (prefers-color-scheme:dark){select.form-control{background-image:var(--select-caret-dark)}}[data-color-scheme=dark] select.form-control{background-image:var(--select-caret-dark)}[data-color-scheme=light] select.form-control{background-image:var(--select-caret-light)}.form-control:focus{border-color:var(--color-primary);outline:var(--focus-outline)}.form-label{margin-bottom:var(--space-8);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);display:block}.card{background-color:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-card-border);box-shadow:var(--shadow-sm);transition:box-shadow var(--duration-normal)var(--ease-standard);overflow:hidden}.card:hover{box-shadow:var(--shadow-md)}.card__body{padding:var(--space-16)}.card__header,.card__footer{padding:var(--space-16);border-bottom:1px solid var(--color-card-border-inner)}.status{padding:var(--space-6)var(--space-12);border-radius:var(--radius-full);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);align-items:center;display:inline-flex}.status--success{background-color:rgba(var(--color-success-rgb,33,128,141),var(--status-bg-opacity));color:var(--color-success);border:1px solid rgba(var(--color-success-rgb,33,128,141),var(--status-border-opacity))}.status--error{background-color:rgba(var(--color-error-rgb,192,21,47),var(--status-bg-opacity));color:var(--color-error);border:1px solid rgba(var(--color-error-rgb,192,21,47),var(--status-border-opacity))}.status--warning{background-color:rgba(var(--color-warning-rgb,168,75,47),var(--status-bg-opacity));color:var(--color-warning);border:1px solid rgba(var(--color-warning-rgb,168,75,47),var(--status-border-opacity))}.status--info{background-color:rgba(var(--color-info-rgb,98,108,113),var(--status-bg-opacity));color:var(--color-info);border:1px solid rgba(var(--color-info-rgb,98,108,113),var(--status-border-opacity))}.container{width:100%;padding-right:var(--space-16);padding-left:var(--space-16);margin-left:auto;margin-right:auto}@media (min-width:640px){.container{max-width:var(--container-sm)}}@media (min-width:768px){.container{max-width:var(--container-md)}}@media (min-width:1024px){.container{max-width:var(--container-lg)}}@media (min-width:1280px){.container{max-width:var(--container-xl)}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-4{gap:var(--space-4)}.gap-8{gap:var(--space-8)}.gap-16{gap:var(--space-16)}.m-0{margin:0}.mt-8{margin-top:var(--space-8)}.mb-8{margin-bottom:var(--space-8)}.mx-8{margin-left:var(--space-8);margin-right:var(--space-8)}.my-8{margin-top:var(--space-8);margin-bottom:var(--space-8)}.p-0{padding:0}.py-8{padding-top:var(--space-8);padding-bottom:var(--space-8)}.px-8{padding-left:var(--space-8);padding-right:var(--space-8)}.py-16{padding-top:var(--space-16);padding-bottom:var(--space-16)}.px-16{padding-left:var(--space-16);padding-right:var(--space-16)}.block{display:block}:focus-visible{outline:var(--focus-outline);outline-offset:2px}[data-color-scheme=dark] .btn--outline{border:1px solid var(--color-border-secondary)}@font-face{font-family:FKGroteskNeue;src:url(https://r2cdn.perplexity.ai/fonts/FKGroteskNeue.woff2)format("woff2")}body{height:100vh;transition:background var(--duration-normal)var(--ease-standard);background:linear-gradient(135deg,#6b46c1 0%,#1e3a8a 50%,#0f172a 100%);margin:0;padding:0;position:relative;overflow:hidden}body.focus-mode{background:var(--color-slate-900)}.header{height:60px;padding:0 var(--space-20);z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;justify-content:space-between;align-items:center;display:flex;position:fixed;top:0;left:0;right:0}.logo svg{color:#fffc;filter:drop-shadow(0 2px 4px #0003)}.btn-icon{border-radius:var(--radius-full);cursor:pointer;width:40px;height:40px;transition:all var(--duration-fast)var(--ease-standard);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;justify-content:center;align-items:center;display:flex}.btn-icon:hover{background:#fff3;border-color:#ffffff4d;transform:translateY(-1px)}.btn-icon svg{color:#ffffffe6}.header-left,.header-right{align-items:center;gap:var(--space-12);display:flex}.main-content{justify-content:center;align-items:center;height:100vh;padding-top:60px;padding-bottom:80px;display:flex}.landing-state{justify-content:center;align-items:center;height:100%;display:flex}.add-sound-btn{border-radius:var(--radius-full);cursor:pointer;width:200px;height:200px;transition:all var(--duration-normal)var(--ease-standard);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff26;border:2px solid #ffffff4d;flex-direction:column;justify-content:center;align-items:center;display:flex;box-shadow:0 8px 32px #0000004d}.add-sound-btn:hover{background:#fff3;border-color:#fff6;transform:scale(1.05);box-shadow:0 12px 40px #0006}.add-icon{color:#ffffffe6;margin-bottom:var(--space-8);font-size:48px;font-weight:300}.add-text{font-size:var(--font-size-xl);color:#fffc;font-weight:var(--font-weight-medium)}.floating-add-btn{bottom:100px;right:var(--space-20);background:var(--color-teal-300);cursor:pointer;width:56px;height:56px;transition:all var(--duration-fast)var(--ease-standard);z-index:800;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:fixed;box-shadow:0 4px 16px #1fb8cd4d}.floating-add-btn:hover{background:var(--color-teal-400);transform:scale(1.05);box-shadow:0 6px 20px #1fb8cd66}.floating-add-btn svg{color:var(--color-slate-900)}.soundscape-canvas{-webkit-user-select:none;user-select:none;touch-action:none;width:100%;height:100%;position:relative;overflow:hidden}.sound-tiles{width:100%;height:100%;position:relative}.sound-tiles:before{content:"+";color:#ffffff0d;pointer-events:none;z-index:0;font-size:40px;font-weight:100;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.sound-tile{cursor:pointer;-webkit-user-select:none;user-select:none;width:120px;height:120px;transition:all var(--duration-fast)var(--ease-standard);border-radius:50%;position:absolute}.sound-tile.dragging{z-index:100;transform:scale(1.15);box-shadow:0 10px 30px #00000080,0 0 25px #1fb8cdb3}.tile-container{width:100%;height:100%;position:relative}.tile-circle{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);width:100%;height:100%;transition:all var(--duration-fast)var(--ease-standard);background:#ffffff26;border:2px solid #ffffff4d;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;animation:2s ease-in-out infinite pulse;display:flex;box-shadow:0 4px 16px #0000004d}.sound-tile:hover .tile-circle{background:#fff3;border-color:#fff6;transform:scale(1.05)}.tile-icon{margin-bottom:var(--space-4);font-size:32px}.tile-name{font-size:var(--font-size-sm);color:#ffffffe6;text-align:center;font-weight:var(--font-weight-medium)}.radial-slider{pointer-events:none;z-index:10;position:absolute;inset:-10px}.radial-slider svg{pointer-events:none;width:100%;height:100%;transform:rotate(-90deg)}.radial-background{fill:none;stroke:#ffffff1a;stroke-width:3px}.radial-progress{fill:none;stroke:var(--color-teal-300);stroke-width:3px;stroke-linecap:round;transition:stroke-dasharray var(--duration-fast)var(--ease-standard);filter:drop-shadow(0 0 6px #1fb8cd80)}.radial-interaction-ring{fill:none;stroke:#0000;stroke-width:22px;cursor:pointer;pointer-events:stroke}.tile-controls{border-radius:var(--radius-lg);padding:var(--space-8);gap:var(--space-8);opacity:0;pointer-events:none;transition:all var(--duration-fast)var(--ease-standard);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:101;background:#000c;display:flex;position:absolute;top:-40px;left:50%;transform:translate(-50%)}.sound-tile.expanded .tile-controls{opacity:1;pointer-events:auto}.control-btn{border-radius:var(--radius-sm);cursor:pointer;width:32px;height:32px;transition:all var(--duration-fast)var(--ease-standard);background:#ffffff1a;border:1px solid #fff3;justify-content:center;align-items:center;display:flex}.control-btn:hover{background:#fff3}.control-btn svg{color:#ffffffe6;width:16px;height:16px}.global-controls{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);height:80px;padding:0 var(--space-20);z-index:900;background:#0000004d;border-top:1px solid #ffffff1a;justify-content:space-between;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.volume-control{flex:1;max-width:300px}.master-volume-slider{border-radius:var(--radius-full);cursor:pointer;appearance:none;background:#fff3;outline:none;width:100%;height:6px}.master-volume-slider::-webkit-slider-thumb{appearance:none;background:var(--color-teal-300);cursor:pointer;border-radius:50%;width:20px;height:20px;box-shadow:0 2px 8px #1fb8cd66}.master-volume-slider::-moz-range-thumb{background:var(--color-teal-300);cursor:pointer;border:none;border-radius:50%;width:20px;height:20px;box-shadow:0 2px 8px #1fb8cd66}.playback-controls{align-items:center;gap:var(--space-16);display:flex}.play-pause-btn{background:var(--color-teal-300);cursor:pointer;width:56px;height:56px;transition:all var(--duration-fast)var(--ease-standard);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;box-shadow:0 4px 16px #1fb8cd4d}.play-pause-btn:hover{background:var(--color-teal-400);transform:scale(1.05);box-shadow:0 6px 20px #1fb8cd66}.play-pause-btn svg{color:var(--color-slate-900)}.sound-drawer{-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg);height:70vh;transition:transform var(--duration-normal)var(--ease-standard);z-index:1100;background:#000000e6;position:fixed;bottom:0;left:0;right:0;overflow:hidden;transform:translateY(100%)}.sound-drawer.visible{transform:translateY(0)}.drawer-header{padding:var(--space-20);border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;display:flex}.drawer-header h3{color:#ffffffe6;margin:0}.drawer-tabs{border-bottom:1px solid #ffffff1a;display:flex}.tab-btn{padding:var(--space-16);color:#fff9;cursor:pointer;transition:all var(--duration-fast)var(--ease-standard);background:0 0;border:none;border-bottom:2px solid #0000;flex:1}.tab-btn:hover,.tab-btn.active{color:#ffffffe6;background:#ffffff0d}.tab-btn.active{border-bottom-color:var(--color-teal-300)}.drawer-content{padding:var(--space-20);height:calc(100% - 140px);overflow-y:auto}.sound-grid{gap:var(--space-16);grid-template-columns:repeat(auto-fill,minmax(100px,1fr));display:grid}.sound-item{border-radius:var(--radius-lg);padding:var(--space-16);text-align:center;cursor:pointer;transition:all var(--duration-fast)var(--ease-standard);-webkit-user-select:none;user-select:none;background:#ffffff1a;border:1px solid #fff3}.sound-item:hover{background:#ffffff26;border-color:#ffffff4d;transform:translateY(-2px)}.sound-item-icon{margin-bottom:var(--space-8);font-size:32px}.sound-item-name{font-size:var(--font-size-sm);color:#fffc;font-weight:var(--font-weight-medium)}.modal{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1200;opacity:0;pointer-events:none;transition:opacity var(--duration-normal)var(--ease-standard);background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal.visible{opacity:1;pointer-events:auto}.modal-content{-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);border-radius:var(--radius-lg);background:#000000e6;border:1px solid #fff3;width:90%;max-width:400px;max-height:80vh;overflow:hidden}.modal-header{padding:var(--space-20);border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;display:flex}.modal-header h3{color:#ffffffe6;margin:0}.modal-body{padding:var(--space-20)}.presets-list{gap:var(--space-8);margin-bottom:var(--space-20);flex-direction:column;display:flex}.preset-item{border-radius:var(--radius-base);padding:var(--space-12);cursor:pointer;transition:all var(--duration-fast)var(--ease-standard);color:#fffc;background:#ffffff1a;border:1px solid #fff3}.preset-item:hover{background:#ffffff26}.timer-presets{gap:var(--space-12);margin-bottom:var(--space-20);grid-template-columns:1fr 1fr;display:grid}.timer-preset-btn{border-radius:var(--radius-base);padding:var(--space-12);color:#fffc;cursor:pointer;transition:all var(--duration-fast)var(--ease-standard);background:#ffffff1a;border:1px solid #fff3}.timer-preset-btn:hover{background:#ffffff26}.timer-display{text-align:center;font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);color:var(--color-teal-300);margin-bottom:var(--space-20);font-family:var(--font-family-mono)}.timer-controls{gap:var(--space-12);display:flex}.timer-controls .btn{flex:1}.focus-toggle{top:50%;right:var(--space-20);border-radius:var(--radius-full);cursor:pointer;width:40px;height:40px;transition:all var(--duration-fast)var(--ease-standard);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;background:#ffffff1a;border:1px solid #fff3;justify-content:center;align-items:center;display:flex;position:fixed;transform:translateY(-50%)}.focus-toggle:hover{background:#fff3;transform:translateY(-50%)scale(1.1)}.focus-toggle svg{color:#fffc;transition:all .2s}.focus-toggle[aria-checked=true]{background:#ec48994d;border-color:#ec489999;animation:1.5s ease-in-out infinite heartbeat}.focus-toggle[aria-checked=true] svg{color:#ec4899;fill:#ec4899}@keyframes heartbeat{0%,to{transform:translateY(-50%)scale(1)}50%{transform:translateY(-50%)scale(1.1)}}.floating-word-input{bottom:100px;right:var(--space-20);z-index:1000;gap:8px;position:fixed;display:none!important}.floating-word-input input{border-radius:var(--radius-full);color:#fff;width:200px;transition:all var(--duration-fast)var(--ease-standard);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;outline:none;padding:10px 14px;font-size:14px}.floating-word-input input::placeholder{color:#ffffff80}.floating-word-input input:focus{background:#ffffff26;border-color:#ec489980}.floating-word-input button{border-radius:var(--radius-full);cursor:pointer;width:40px;height:40px;transition:all var(--duration-fast)var(--ease-standard);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ec48994d;border:1px solid #ec489980;font-size:16px}.floating-word-input button:hover:not(:disabled){background:#ec489980;transform:scale(1.1)}.floating-word-input button:disabled{opacity:.5;cursor:not-allowed}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}.sound-tile.playing .tile-circle{animation:1.5s ease-in-out infinite pulse}.hidden{display:none!important}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (max-width:768px){.header{padding:0 var(--space-16)}.header-right{gap:var(--space-8)}.user-name{display:none}.user-profile{gap:var(--space-8);border-left:none;padding-left:0}.global-controls{padding:0 var(--space-16)}.add-sound-btn{width:160px;height:160px}.sound-tile{width:100px;height:100px}.tile-icon{font-size:24px}.sound-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.floating-add-btn{bottom:170px;right:var(--space-16)}.floating-word-input{display:none!important}.zoom-controls{display:none}.preset-sidebar{width:85%;max-width:320px}.sound-drawer{height:85vh}.btn-icon{min-width:44px;min-height:44px}.preset-item,.sound-item{min-height:44px;padding:var(--space-12)}.focus-toggle{right:var(--space-12)}}.highlight-tile{z-index:200;animation:.5s ease-in-out highlight-pulse;transform:scale(1.1)!important;box-shadow:0 0 20px 10px #fff6!important}@keyframes highlight-pulse{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.floating-text-container{pointer-events:none;z-index:500;height:calc(100vh - 140px);position:fixed;bottom:80px;left:0;right:0;overflow:hidden}.floating-bubble{padding:var(--space-12)var(--space-20);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-full);color:#fffffff2;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);white-space:normal;word-wrap:break-word;overflow-wrap:break-word;opacity:0;text-align:center;pointer-events:auto;cursor:pointer;background:#ffffff26;border:1px solid #ffffff4d;width:auto;min-width:200px;max-width:80vw;transition:all .3s;animation:15s ease-in-out forwards floatUp;position:absolute;bottom:-100px;box-shadow:0 8px 32px #0003}.floating-bubble:hover{transform:scale(1.05);box-shadow:0 0 15px #ffffff4d}.floating-bubble.expanded{white-space:normal;word-wrap:break-word;overflow-wrap:break-word;width:auto;min-width:200px;max-width:80vw;padding:var(--space-16)var(--space-24);z-index:1000;animation-play-state:paused;transform:scale(1.1);box-shadow:0 0 30px #fff6}.floating-bubble .bubble-username{font-weight:var(--font-weight-bold);color:#fff;margin-right:var(--space-4)}.floating-bubble .bubble-title,.floating-bubble .bubble-content{font-weight:var(--font-weight-normal);display:inline}.floating-bubble .bubble-expand-hint{font-size:var(--font-size-sm);opacity:.6;font-style:italic}@keyframes floatUp{0%{opacity:0;bottom:-100px;transform:translateY(0)translate(0)}5%{opacity:1}90%{opacity:1}to{opacity:0;transform:translateY(-50px)translateX(var(--drift-x,0px));bottom:100%}}.floating-bubble.voice-bubble{cursor:pointer;background:linear-gradient(135deg,#9370dbe6,#8a2be2e6);border:1px solid #9370db80;animation:16s ease-in-out forwards floatUp}.floating-bubble.voice-bubble:hover{transform:scale(1.05);box-shadow:0 0 20px #9370db99}.floating-bubble.voice-bubble.expanded{box-shadow:0 0 30px #9370dbcc}.floating-bubble .voice-icon{margin-right:4px}.zoom-controls{top:80px;right:var(--space-20);gap:var(--space-8);z-index:1000;padding:var(--space-8);border-radius:var(--radius-base);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#00000080;border:1px solid #ffffff1a;flex-direction:column;display:flex;position:fixed}.zoom-level{color:var(--color-white);font-size:var(--font-size-xs);text-align:center;font-family:var(--font-family-mono)}.zoom-btn{width:32px;height:32px}.preset-sidebar{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);width:280px;transition:transform var(--duration-normal)var(--ease-standard);z-index:950;background:#000c;border-right:1px solid #ffffff1a;flex-direction:column;display:flex;position:fixed;top:60px;bottom:80px;left:0;transform:translate(-100%)}.preset-sidebar.visible{transform:translate(0)}.sidebar-header{padding:var(--space-16);border-bottom:1px solid #ffffff1a}.sidebar-header h3{color:var(--color-white);font-size:var(--font-size-lg);margin:0}.sidebar-content{padding:var(--space-16);flex:1;overflow-y:auto}.sidebar-footer{padding:var(--space-16);border-top:1px solid #ffffff1a}.sidebar-toggle{border-top-right-radius:var(--radius-base);border-bottom-right-radius:var(--radius-base);width:24px;height:48px;color:var(--color-white);cursor:pointer;transition:background var(--duration-fast);background:#000c;border:1px solid #ffffff1a;border-left:none;justify-content:center;align-items:center;margin-top:-24px;display:flex;position:absolute;top:50%;right:-24px}.sidebar-toggle:hover{background:#ffffff1a}.preset-sidebar.visible .sidebar-toggle svg{transform:rotate(180deg)}.soundscape-canvas{perspective:1000px;overflow:hidden}.zoom-container{transform-origin:50%;width:100%;height:100%;transition:transform .1s ease-out}.sound-tiles{width:100%;height:100%;position:absolute;top:0;left:0}.modal-overlay{z-index:1200;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000000b3;justify-content:center;align-items:center;animation:.2s ease-in-out fadeIn;display:flex;position:fixed;inset:0}.auth-modal{background:var(--color-surface);border-radius:var(--radius-lg);z-index:1201;width:90%;max-width:450px;max-height:90vh;padding:2.5rem;animation:.3s ease-out slideUp;position:relative;overflow-y:auto;box-shadow:0 20px 50px #00000080}.auth-modal h2{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);text-align:center;color:var(--color-text);margin-bottom:1.5rem}.auth-error{background:rgba(var(--color-error-rgb),.1);border:1px solid rgba(var(--color-error-rgb),.3);color:var(--color-error);font-size:var(--font-size-sm);border-radius:8px;margin-bottom:1rem;padding:.75rem}.invitation-section{margin-bottom:1.5rem}.invitation-section label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text);margin-bottom:.5rem;display:block}.invitation-input-group{gap:.5rem;display:flex}.invitation-input-group input{border:1px solid var(--color-border);font-size:var(--font-size-base);font-family:var(--font-family-mono);text-transform:uppercase;border-radius:8px;flex:1;padding:.75rem}.invitation-input-group button{background:var(--color-secondary);border:1px solid var(--color-border);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;border-radius:8px;padding:.75rem 1rem;transition:all .2s}.invitation-input-group button:hover:not(:disabled){background:var(--color-secondary-hover)}.invitation-input-group button:disabled{opacity:.5;cursor:not-allowed}.invitation-input-group button.validated{background:rgba(var(--color-success-rgb),.2);border-color:var(--color-success);color:var(--color-success)}.invitation-section small{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:.5rem;display:block}.google-signin-btn{border:1px solid var(--color-border);width:100%;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;background:#fff;border-radius:8px;justify-content:center;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.875rem;transition:all .2s;display:flex}.google-signin-btn:hover:not(:disabled){background:var(--color-gray-200)}.google-signin-btn:disabled{opacity:.5;cursor:not-allowed}.google-icon{width:20px;height:20px;font-weight:var(--font-weight-bold);color:#4285f4;justify-content:center;align-items:center;display:flex}.auth-divider{color:var(--color-text-secondary);font-size:var(--font-size-sm);align-items:center;margin:1.5rem 0;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--color-border);flex:1;height:1px}.auth-divider span{padding:0 1rem}.form-group{margin-bottom:1rem}.form-group label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text);margin-bottom:.5rem;display:block}.form-group input,.form-group textarea{border:1px solid var(--color-border);width:100%;font-size:var(--font-size-base);font-family:var(--font-family-base);border-radius:8px;padding:.75rem;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{border-color:var(--color-primary);box-shadow:var(--focus-ring);outline:none}.form-group small{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:.25rem;display:block}.submit-btn{background:var(--color-primary);width:100%;color:var(--color-btn-primary-text);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;border:none;border-radius:8px;padding:.875rem;transition:background .2s}.submit-btn:hover:not(:disabled){background:var(--color-primary-hover)}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.auth-toggle{text-align:center;font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:1.5rem}.auth-toggle button{color:var(--color-primary);font-weight:var(--font-weight-medium);cursor:pointer;background:0 0;border:none;text-decoration:underline}.auth-toggle button:hover{color:var(--color-primary-hover)}.chat-bubble{z-index:10;max-width:280px;animation:.6s cubic-bezier(.34,1.56,.64,1) floatIn;position:absolute}@keyframes floatIn{0%{opacity:0;transform:translateY(20px)scale(.8)}to{opacity:1;transform:translateY(0)scale(1)}}.chat-bubble.dragging{z-index:100;cursor:grabbing!important}.chat-bubble-content{background:var(--color-surface);border:1px solid var(--color-card-border);border-radius:16px;padding:.75rem 1rem;position:relative;box-shadow:0 4px 12px #0000001a}.chat-bubble.own .chat-bubble-content{background:rgba(var(--color-teal-500-rgb),.1);border-color:var(--color-primary)}.chat-bubble-header{font-size:var(--font-size-xs);justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.chat-bubble-author{font-weight:var(--font-weight-medium);color:var(--color-text)}.chat-bubble-time{color:var(--color-text-secondary)}.chat-bubble-text{font-size:var(--font-size-base);color:var(--color-text);word-wrap:break-word}.chat-bubble-delete{background:var(--color-error);color:#fff;border:2px solid var(--color-surface);cursor:pointer;border-radius:50%;width:24px;height:24px;font-size:16px;line-height:1;display:none;position:absolute;top:-8px;right:-8px}.chat-bubble:hover .chat-bubble-delete{display:block}.chat-bubble-tail{background:var(--color-surface);border-right:1px solid var(--color-card-border);border-bottom:1px solid var(--color-card-border);width:12px;height:12px;position:absolute;bottom:-6px;left:20px;transform:rotate(45deg)}.chat-bubble.own .chat-bubble-tail{background:rgba(var(--color-teal-500-rgb),.1);border-color:var(--color-primary)}.chat-input-container{z-index:50;width:90%;max-width:600px;position:fixed;bottom:80px;left:50%;transform:translate(-50%)}.chat-input-form{background:var(--color-surface);border:1px solid var(--color-card-border);border-radius:16px;padding:1rem;box-shadow:0 4px 20px #00000026}.chat-input-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.anonymous-toggle{font-size:var(--font-size-sm);cursor:pointer;align-items:center;gap:.5rem;display:flex}.anonymous-toggle input[type=checkbox]{cursor:pointer;width:16px;height:16px}.word-counter{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.word-counter.over-limit{color:var(--color-error);font-weight:var(--font-weight-medium)}.chat-input-row{gap:.75rem;display:flex}.chat-input-row input{border:1px solid var(--color-border);font-size:var(--font-size-base);border-radius:8px;flex:1;padding:.75rem}.chat-input-row button{background:var(--color-primary);color:var(--color-btn-primary-text);font-weight:var(--font-weight-medium);cursor:pointer;border:none;border-radius:8px;padding:.75rem 1.5rem;transition:background .2s}.chat-input-row button:hover:not(:disabled){background:var(--color-primary-hover)}.chat-input-row button:disabled{opacity:.5;cursor:not-allowed}.voice-recorder-bottom{z-index:1000;pointer-events:none;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.recorder-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:auto;background:#00000080;animation:.2s ease-out fadeIn;position:absolute;inset:0}.recorder-panel{background:var(--color-surface);pointer-events:auto;border-radius:20px 20px 0 0;width:100%;max-width:700px;max-height:80vh;margin:0 1rem;padding:1.5rem;animation:.3s cubic-bezier(.34,1.56,.64,1) slideUpIn;position:relative;overflow-y:auto;box-shadow:0 -4px 30px #0003}@keyframes slideUpIn{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.recorder-header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.recorder-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text);margin:0}.mode-toggle{background:var(--color-secondary);border-radius:10px;gap:.5rem;padding:.25rem;display:flex}.mode-btn{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;border-radius:8px;padding:.5rem 1rem;transition:all .2s}.mode-btn:hover:not(:disabled){background:#0000000d}.mode-btn.active{background:var(--color-surface);color:var(--color-text);box-shadow:0 2px 4px #0000001a}.mode-btn:disabled{opacity:.5;cursor:not-allowed}.close-btn{background:var(--color-secondary);cursor:pointer;width:32px;height:32px;color:var(--color-text-secondary);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:20px;transition:all .2s;display:flex}.close-btn:hover:not(:disabled){background:var(--color-red-100);color:var(--color-error)}.close-btn:disabled{opacity:.5;cursor:not-allowed}.recorder-content{flex-direction:column;gap:1rem;display:flex}.form-field{flex-direction:column;gap:.5rem;display:flex}.form-field input,.form-field textarea{border:2px solid var(--color-border);width:100%;font-size:var(--font-size-base);color:var(--color-text);background:var(--color-surface);resize:vertical;border-radius:12px;padding:.875rem 1rem;font-family:inherit;transition:border-color .2s}.form-field input:focus,.form-field textarea:focus{border-color:var(--color-primary);outline:none}.form-field input:disabled,.form-field textarea:disabled{opacity:.6;cursor:not-allowed;background:var(--color-secondary)}.char-count{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-align:right}.voice-controls{background:var(--color-secondary);border-radius:12px;padding:1rem}.recording-area{justify-content:center;align-items:center;min-height:100px;display:flex}.record-start-btn{background:var(--color-error);color:#fff;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;border:none;border-radius:50px;align-items:center;gap:.75rem;padding:1rem 2rem;transition:all .2s;display:flex}.record-start-btn:hover:not(:disabled){background:var(--color-red-400);transform:scale(1.05)}.record-start-btn:disabled{opacity:.5;cursor:not-allowed}.record-icon{font-size:1.5rem}.recording-active{flex-direction:column;align-items:center;gap:1rem;display:flex}.recording-pulse{justify-content:center;align-items:center;display:flex}.pulse-dot{background:var(--color-error);border-radius:50%;width:16px;height:16px;animation:1.5s infinite pulse}.recording-time{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-error);font-variant-numeric:tabular-nums}.record-stop-btn{background:var(--color-slate-600);color:#fff;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;border:none;border-radius:50px;padding:.75rem 1.5rem;transition:all .2s}.record-stop-btn:hover{background:var(--color-slate-700)}.audio-preview-area{flex-direction:column;align-items:center;gap:1rem;display:flex}.audio-preview-area audio{width:100%;max-width:400px}.re-record-btn{background:var(--color-secondary);border:1px solid var(--color-border);font-size:var(--font-size-sm);cursor:pointer;border-radius:8px;padding:.5rem 1rem;transition:all .2s}.re-record-btn:hover:not(:disabled){background:var(--color-secondary-hover)}.re-record-btn:disabled{opacity:.5;cursor:not-allowed}.recorder-actions{gap:1rem;margin-top:.5rem;display:flex}.btn-cancel{background:var(--color-secondary);border:1px solid var(--color-border);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;border-radius:12px;flex:1;padding:.875rem;transition:all .2s}.btn-cancel:hover:not(:disabled){background:var(--color-secondary-hover)}.btn-cancel:disabled{opacity:.5;cursor:not-allowed}.btn-submit{background:var(--color-primary);color:var(--color-btn-primary-text);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;border:none;border-radius:12px;flex:2;padding:.875rem;transition:all .2s}.btn-submit:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px)}.btn-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}@media (max-width:768px){.recorder-panel{border-radius:20px 20px 0 0;max-height:85vh;margin:0}.recorder-header{flex-wrap:wrap}.mode-toggle{order:3;width:100%}.mode-btn{flex:1}}.voice-recorder-container{background:var(--color-surface);border-radius:16px;max-width:500px;margin:2rem auto;padding:2rem}.recorder-choice h3,.recorder-voice h3,.recorder-text h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);text-align:center;margin-bottom:1rem}.choice-buttons{gap:1rem;margin:2rem 0;display:flex}.choice-btn{background:var(--color-secondary);border:2px solid var(--color-border);cursor:pointer;border-radius:12px;flex-direction:column;flex:1;align-items:center;gap:.75rem;padding:2rem 1rem;transition:all .2s;display:flex}.choice-btn:hover{background:var(--color-secondary-hover);transform:translateY(-2px)}.choice-icon{font-size:3rem}.choice-btn span:last-child{font-weight:var(--font-weight-medium)}.recording-controls{text-align:center;margin:2rem 0}.record-btn,.stop-btn{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;border:none;border-radius:50px;align-items:center;gap:.5rem;padding:1rem 2rem;transition:all .2s;display:inline-flex}.record-btn{background:var(--color-error);color:#fff}.record-btn:hover{background:var(--color-red-400)}.stop-btn{background:var(--color-slate-500);color:#fff}.recording-indicator{font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);justify-content:center;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.pulse{background:var(--color-error);border-radius:50%;width:12px;height:12px;animation:1.5s infinite pulse}.audio-preview{text-align:center;margin:2rem 0}.audio-preview audio{width:100%;margin-bottom:1rem}.reset-btn{background:var(--color-secondary);border:1px solid var(--color-border);cursor:pointer;border-radius:8px;padding:.5rem 1rem}.form-actions{gap:1rem;margin-top:1.5rem;display:flex}.upload-btn{background:var(--color-primary);color:var(--color-btn-primary-text);font-weight:var(--font-weight-medium);cursor:pointer;border:none;border-radius:8px;flex:1;padding:.875rem}.upload-btn:hover:not(:disabled){background:var(--color-primary-hover)}.cancel-btn{background:var(--color-secondary);border:1px solid var(--color-border);cursor:pointer;border-radius:8px;padding:.875rem 1.5rem}.contribution-bubble{cursor:pointer;z-index:10;width:140px;height:140px;animation:.6s cubic-bezier(.34,1.56,.64,1) floatIn;position:absolute}.contribution-bubble.dragging{z-index:100;cursor:grabbing!important}.contribution-bubble-content{background:var(--color-surface);border:2px solid var(--color-card-border);text-align:center;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:1rem;transition:all .3s;display:flex;position:relative;box-shadow:0 4px 12px #0000001a}.contribution-bubble:hover .contribution-bubble-content{transform:scale(1.05);box-shadow:0 6px 20px #00000026}.contribution-bubble.voice .contribution-bubble-content{border-color:var(--color-primary)}.contribution-bubble.text .contribution-bubble-content{border-color:var(--color-orange-400)}.contribution-bubble.playing .contribution-bubble-content{background:rgba(var(--color-teal-500-rgb),.15);animation:1s infinite soundWave}@keyframes soundWave{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.contribution-icon{margin-bottom:.5rem;font-size:2rem}.contribution-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text);text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.contribution-duration,.contribution-author{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:.25rem}.contribution-text-popup{background:var(--color-surface);border:1px solid var(--color-card-border);z-index:1000;border-radius:12px;width:300px;max-height:400px;margin-top:1rem;padding:1rem;position:absolute;top:100%;left:50%;overflow-y:auto;transform:translate(-50%);box-shadow:0 8px 24px #0003}.popup-header{justify-content:space-between;align-items:flex-start;margin-bottom:1rem;display:flex}.popup-header h4{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);flex:1}.popup-header button{cursor:pointer;background:0 0;border:none;width:24px;height:24px;padding:0;font-size:24px}.popup-content{font-size:var(--font-size-sm);color:var(--color-text);white-space:pre-wrap;line-height:1.6}.popup-description{border-top:1px solid var(--color-border);font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:1rem;padding-top:1rem}.contribution-delete{background:var(--color-error);color:#fff;border:2px solid var(--color-surface);cursor:pointer;border-radius:50%;width:28px;height:28px;font-size:18px;line-height:1;display:none;position:absolute;top:-8px;right:-8px}.contribution-bubble:hover .contribution-delete{display:block}.logo-text{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-left:var(--space-12);color:var(--color-white)}.user-profile{align-items:center;gap:var(--space-12);padding-left:var(--space-12);border-left:1px solid #fff3;display:flex}.user-name{font-size:var(--font-size-sm);color:var(--color-white);font-weight:var(--font-weight-medium)}.btn-primary{padding:var(--space-8)var(--space-16);background:var(--color-primary);color:var(--color-btn-primary-text);border-radius:var(--radius-base);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--duration-fast)var(--ease-standard);border:none}.btn-primary:hover{background:var(--color-primary-hover)}.btn-text{padding:var(--space-8)var(--space-12);color:#fffc;border-radius:var(--radius-base);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--duration-fast)var(--ease-standard);background:0 0;border:1px solid #fff3}.btn-text:hover{color:var(--color-white);background:#ffffff1a}.modal-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10000;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--color-surface);border:1px solid var(--color-card-border);border-radius:16px;max-width:90vw;max-height:90vh;position:relative;overflow-y:auto;box-shadow:0 10px 40px #0000004d}.modal-close{cursor:pointer;z-index:10;background:#0000001a;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:24px;line-height:1;transition:background .2s;display:flex;position:absolute;top:1rem;right:1rem}.modal-close:hover{background:#0003}.recorder-modal{max-width:600px;padding:0}.landing-page{width:100%;height:100%;color:var(--text-color);z-index:9999;background:linear-gradient(300deg,#020024,#090979,#6a0dad,#ff8c00,#d90429) 0 0/400% 400%;justify-content:center;align-items:center;animation:25s infinite moodShift;display:flex;position:relative;top:0;left:0;overflow:hidden}@keyframes moodShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}.bubble-container{pointer-events:none;z-index:1;width:100%;height:100%;position:absolute;top:0;left:0}.galaxy-bubble{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;background:radial-gradient(circle at 30% 30%,#ffffff1a,#ffffff03);border:1px solid #ffffff26;border-radius:50%;animation:linear infinite floatBubble;position:absolute;box-shadow:0 0 15px #ffffff1a,inset 0 0 10px #ffffff1a}@keyframes floatBubble{0%{opacity:0;transform:translateY(110vh)translate(0)rotate(0)}10%{opacity:1}90%{opacity:1}to{opacity:0;transform:translateY(-20vh)translate(20px)rotate(360deg)}}.landing-content{z-index:10;text-align:center;position:relative}.landing-logo{letter-spacing:4px;text-transform:uppercase;text-shadow:0 0 20px #ffffff80;opacity:.9;color:#fff;width:100%;margin-bottom:2rem;font-size:2rem;font-weight:300;position:absolute;top:-150px}.enter-galaxy-btn{-webkit-backdrop-filter:blur(10px);color:#fff;letter-spacing:1px;cursor:pointer;text-transform:uppercase;background:#ffffff1a;border:none;border-radius:50%;outline:none;flex-direction:column;justify-content:center;align-items:center;width:220px;height:220px;font-size:1.2rem;font-weight:700;transition:all .4s;animation:3s ease-in-out infinite corePulse;display:flex;position:relative;box-shadow:0 0 30px #fff3,inset 0 0 40px #ffffff1a}.enter-galaxy-btn:after{content:"+";margin-bottom:10px;font-size:2rem;display:block}.enter-galaxy-btn:hover{color:#fff;background:#ffffff26;transform:scale(1.1);box-shadow:0 0 60px #fff6,inset 0 0 20px #fff3}.enter-galaxy-btn:active{transform:scale(.95)}@keyframes corePulse{0%{box-shadow:0 0 30px #fff3,inset 0 0 40px #ffffff1a}50%{box-shadow:0 0 50px #fff6,inset 0 0 40px #ffffff1a}to{box-shadow:0 0 30px #fff3,inset 0 0 40px #ffffff1a}}
