@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap";*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html,body{height:100%;overflow-x:hidden}body{color:#1a1a1a;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fff;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}#app{flex-direction:column;min-height:100dvh;display:flex}.screen{flex-direction:column;width:100%;max-width:480px;min-height:100dvh;margin:0 auto;padding:0 20px;animation:.25s screenFadeIn;display:none}.screen.active{display:flex}@keyframes screenFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}h1{letter-spacing:-.04em;font-size:2rem;font-weight:900}h2{letter-spacing:-.03em;font-size:1.4rem;font-weight:800}h3{font-size:1.1rem;font-weight:700}.btn{letter-spacing:.01em;cursor:pointer;-webkit-user-select:none;user-select:none;border:none;border-radius:50px;justify-content:center;align-items:center;gap:8px;padding:14px 28px;font-family:inherit;font-size:.95rem;font-weight:700;transition:transform .15s,box-shadow .15s,background .15s;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{color:#fff;background:#1a1a1a;box-shadow:0 2px 12px #0000002e}.btn-primary:hover{background:#333;box-shadow:0 4px 20px #00000038}.btn-outline{color:#1a1a1a;background:0 0;border:2px solid #1a1a1a}.btn-outline:hover{color:#fff;background:#1a1a1a}.btn-ghost{color:#666;background:0 0;padding:10px 16px}.btn-ghost:hover{color:#1a1a1a;background:#f5f5f5;border-radius:12px}.btn-google{color:#1a1a1a;background:#fff;border:1.5px solid #e0e0e0;box-shadow:0 1px 6px #00000014}.btn-google:hover{box-shadow:0 3px 12px #00000021}.btn-full{width:100%}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.input-group{flex-direction:column;gap:6px;display:flex}.input-group label{color:#555;letter-spacing:.06em;text-transform:uppercase;font-size:.8rem;font-weight:600}.input-field{color:#1a1a1a;background:#fafafa;border:1.5px solid #e0e0e0;border-radius:12px;outline:none;width:100%;padding:13px 16px;font-family:inherit;font-size:.95rem;transition:border-color .15s,box-shadow .15s}.input-field:focus{background:#fff;border-color:#1a1a1a;box-shadow:0 0 0 3px #0000000f}.input-field::placeholder{color:#bbb}.divider{color:#ccc;align-items:center;gap:12px;font-size:.85rem;display:flex}.divider:before,.divider:after{content:"";background:#e8e8e8;flex:1;height:1px}.logo-mark{align-items:center;gap:0;display:flex}.logo-circles{flex-shrink:0;width:36px;height:32px;position:relative}.logo-circles span{background:0 0;border:2.5px solid #1a1a1a;border-radius:50%;width:20px;height:20px;position:absolute}.logo-circles span:first-child{top:0;left:0}.logo-circles span:nth-child(2){top:0;left:10px}.logo-circles span:nth-child(3){top:10px;left:5px}.logo-text{letter-spacing:-.05em;color:#1a1a1a;font-size:1.4rem;font-weight:900}#toast-container{z-index:9999;pointer-events:none;flex-direction:column;align-items:center;gap:8px;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.toast{color:#fff;white-space:nowrap;pointer-events:auto;background:#1a1a1a;border-radius:50px;padding:10px 20px;font-size:.88rem;font-weight:600;animation:.25s forwards toastIn}.toast.error{background:#ef4444}.toast.success{background:#22c55e}@keyframes toastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}.error-msg{color:#ef4444;min-height:18px;font-size:.82rem;font-weight:500}.spinner{border:2.5px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:22px;height:22px;animation:.7s linear infinite spin;display:inline-block}.spinner.dark{border-color:#1a1a1a #0000001a #0000001a}@keyframes spin{to{transform:rotate(360deg)}}.stat-chip{flex-direction:column;align-items:center;gap:2px;display:flex}.stat-chip .stat-value{letter-spacing:-.04em;font-size:1.8rem;font-weight:900;line-height:1}.stat-chip .stat-label{color:#888;text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;font-weight:600}.modal-overlay{z-index:1000;background:#00000059;justify-content:center;align-items:flex-end;animation:.2s overlayIn;display:flex;position:fixed;inset:0}.modal-overlay.hidden{display:none}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.modal-sheet{background:#fff;border-radius:24px 24px 0 0;width:100%;max-width:480px;padding:28px 24px 40px;animation:.3s cubic-bezier(.34,1.56,.64,1) sheetUp}@keyframes sheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.confetti-piece{pointer-events:none;z-index:9998;border-radius:2px;width:8px;height:8px;animation:linear forwards confettiFall;position:fixed}@keyframes confettiFall{0%{opacity:1;transform:translateY(-20px)rotate(0)}to{opacity:0;transform:translateY(100vh)rotate(720deg)}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.shake{animation:.4s shake}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}.word-bank{flex-wrap:wrap;place-content:flex-start center;gap:6px;width:100%;height:110px;margin:0 auto;padding:8px 0 4px;display:flex}.word-pill{letter-spacing:.02em;color:#1a1a1a;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;background:#f5f5f5;border:1.5px solid #e0e0e0;border-radius:50px;justify-content:center;align-items:center;padding:5px 10px;font-family:Inter,sans-serif;font-size:clamp(.65rem,2.5vw,.8rem);font-weight:700;transition:background .15s,border-color .15s,transform .15s,box-shadow .15s,opacity .15s;display:inline-flex;position:relative}.word-pill:hover{background:#ebebeb;border-color:silver;transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.word-pill.selected{color:#fff;background:#1a1a1a;border-color:#1a1a1a;transform:translateY(-2px);box-shadow:0 6px 20px #00000040}.word-pill.dragging{opacity:.5;cursor:grabbing;transform:scale(.95)}.word-pill.placed{z-index:10;white-space:nowrap;border-width:1.5px;padding:4px 6px;font-size:.65rem;position:absolute;box-shadow:0 2px 4px #0000000d}.word-pill.correct{background:#dcfce7!important;border-color:#22c55e!important}.word-pill.incorrect{background:#fee2e2!important;border-color:#ef4444!important}.word-pill:active{cursor:grabbing}@media (width<=380px){.word-pill{padding:6px 12px;font-size:.75rem}}#auth-screen{text-align:center;justify-content:center;align-items:center;padding:0}.auth-logo{margin-bottom:16px}.auth-logo .logo-mark{justify-content:center;transform:translate(-5px)}.auth-tagline{color:#888;margin-top:4px;font-size:.9rem;font-weight:400}.auth-form{flex-direction:column;gap:16px;width:100%;display:flex}.auth-switch{text-align:center;color:#888;margin-top:8px;font-size:.85rem}.auth-switch a{color:#1a1a1a;cursor:pointer;font-weight:700;text-decoration:none}.auth-switch a:hover{text-decoration:underline}.otp-inputs{justify-content:center;gap:10px;display:flex}.otp-digit{text-align:center;border:1.5px solid #e0e0e0;border-radius:12px;outline:none;width:48px;height:56px;font-family:inherit;font-size:1.4rem;font-weight:800;transition:border-color .15s}.otp-digit:focus{border-color:#1a1a1a;box-shadow:0 0 0 3px #0000000f}#home-screen{justify-content:flex-start;gap:0;height:100dvh;padding-top:0;overflow:hidden}.home-header{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:20px 0 16px;display:flex}.home-header-logo{align-items:center;gap:8px;display:flex}.header-actions{gap:4px;display:flex}.icon-btn{cursor:pointer;color:#666;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.1rem;transition:background .15s,color .15s;display:flex}.icon-btn:hover{color:#1a1a1a;background:#f5f5f5}.home-greeting{border-bottom:1px solid #f0f0f0;padding:32px 0 24px}.greeting-text{color:#888;margin-bottom:4px;font-size:.85rem;font-weight:500}.greeting-name{letter-spacing:-.04em;font-size:1.6rem;font-weight:900}.home-stats{border-bottom:1px solid #f0f0f0;gap:0;padding:24px 0;display:flex}.home-stats .stat-chip{border-right:1px solid #f0f0f0;flex:1}.home-stats .stat-chip:last-child{border-right:none}.daily-card{border:1.5px solid #1a1a1a;border-radius:20px;margin:24px 0;padding:24px;position:relative;overflow:hidden}.daily-card:before{content:"";border:2px solid #0000000f;border-radius:50%;width:120px;height:120px;position:absolute;top:-30px;right:-30px}.daily-card:after{content:"";border:2px solid #00000014;border-radius:50%;width:80px;height:80px;position:absolute;top:-15px;right:-15px}.daily-date{text-transform:uppercase;letter-spacing:.1em;color:#888;margin-bottom:6px;font-size:.75rem;font-weight:700}.daily-title{letter-spacing:-.02em;margin-bottom:20px;font-size:1.1rem;font-weight:800}.daily-card .btn-primary{width:100%}.daily-completed-badge{color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:50px;align-items:center;gap:6px;margin-bottom:12px;padding:8px 16px;font-size:.85rem;font-weight:700;display:inline-flex}.home-menu{flex-direction:column;gap:2px;margin-top:8px;padding-bottom:32px;display:flex}.menu-item{cursor:pointer;color:inherit;border-bottom:1px solid #f5f5f5;justify-content:space-between;align-items:center;padding:16px 4px;text-decoration:none;transition:padding-left .15s;display:flex}.menu-item:hover{padding-left:8px}.menu-item:last-child{border-bottom:none}.menu-item-left{align-items:center;gap:14px;display:flex}.menu-icon{background:#f5f5f5;border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;font-size:1rem;display:flex}.menu-label{font-size:.95rem;font-weight:600}.menu-chevron{color:#ccc;font-size:.9rem}#puzzle-screen{gap:0;height:100dvh;max-height:100dvh;padding-top:0;overflow:hidden}.puzzle-header{border-bottom:1px solid #f0f0f0;flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 0 8px;display:flex}.puzzle-header-center{text-align:center}.puzzle-title-text{letter-spacing:-.02em;font-size:1rem;font-weight:800}.puzzle-date-text{color:#888;font-size:.75rem;font-weight:500}.puzzle-content{flex-direction:column;flex:1;min-height:0;padding:4px 0;display:flex;overflow-y:hidden}.venn-wrapper{touch-action:none;-webkit-user-select:none;user-select:none;flex:1;justify-content:center;align-items:center;min-height:0;padding:0;display:flex;overflow:visible;container-type:size}.venn-container-inner{touch-action:none;-webkit-user-select:none;user-select:none;width:100cqmin;max-width:460px;height:100cqmin;max-height:460px;margin:0 auto;position:relative}.criteria-section{flex-direction:column;flex-shrink:0;gap:6px;padding:12px 0 8px;display:flex}.criteria-row{align-items:flex-start;gap:10px;display:flex}.criteria-dot{background:0 0;border:2px solid #1a1a1a;border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:5px}.criteria-text{color:#555;flex:1;font-size:.85rem;font-weight:500}.hint-row{flex-shrink:0;gap:8px;padding:8px 0;display:flex}.hint-btn{color:#555;cursor:pointer;background:#fafafa;border:1.5px solid #e0e0e0;border-radius:50px;align-items:center;gap:6px;padding:8px 14px;font-family:inherit;font-size:.8rem;font-weight:600;transition:border-color .15s,background .15s,color .15s;display:inline-flex}.hint-btn:hover{color:#1a1a1a;background:#f0f0f0;border-color:#1a1a1a}.words-label{text-transform:uppercase;letter-spacing:.1em;color:#aaa;text-align:center;flex-shrink:0;padding-top:4px;font-size:.7rem;font-weight:700}.puzzle-footer{flex-shrink:0;padding:8px 0 16px}.puzzle-instruction{text-align:center;color:#aaa;margin-bottom:12px;font-size:.82rem;font-weight:500}.hint-tooltip{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#1a1a1a;background:#fffc;border:1px solid #e0e0e0;border-radius:16px;margin:0;padding:14px 20px;font-size:.9rem;line-height:1.5;animation:.2s screenFadeIn;position:absolute;bottom:0;left:0;right:0;box-shadow:0 4px 12px #0000000f}.hint-tooltip strong{text-transform:uppercase;letter-spacing:.08em;color:#888;margin-bottom:4px;font-size:.7rem;display:block}.hint-close-btn{color:#888;cursor:pointer;background:0 0;border:none;padding:0;font-size:1.2rem;line-height:1;transition:color .15s;position:absolute;top:8px;right:12px}.hint-close-btn:hover{color:#1a1a1a}#success-screen{text-align:center;flex-direction:column;justify-content:flex-start;align-items:center;gap:0;height:100dvh;max-height:100dvh;padding-top:40px;padding-bottom:40px;display:flex;overflow:hidden}.success-icon{margin-bottom:16px;font-size:3.5rem;animation:1s infinite pulse}.success-title{letter-spacing:-.04em;margin-bottom:6px;font-size:2rem;font-weight:900}.success-subtitle{color:#888;margin-bottom:32px;font-size:.95rem;font-weight:500}.success-stats{background:#f9f9f9;border-radius:20px;justify-content:center;gap:32px;width:100%;margin-bottom:32px;padding:24px 32px;display:flex}.success-actions{flex-direction:column;gap:12px;width:100%;display:flex}.share-card-preview{color:#fff;text-align:left;background:#1a1a1a;border-radius:16px;width:100%;margin:16px 0;padding:20px}.share-card-preview .share-title{text-transform:uppercase;letter-spacing:.1em;color:#888;margin-bottom:8px;font-size:.75rem;font-weight:700}.share-card-preview .share-text{white-space:pre-line;color:#fff;font-size:.9rem;line-height:1.6}.panel-header{border-bottom:1px solid #f0f0f0;align-items:center;gap:12px;padding:20px 0 16px;display:flex}.panel-title{font-size:1.1rem;font-weight:800}.profile-avatar{color:#fff;letter-spacing:-.03em;background:#1a1a1a;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 16px;font-size:1.8rem;font-weight:900;display:flex}.loading-state{color:#888;flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:60vh;font-size:.9rem;font-weight:500;display:flex}.no-puzzle-state{text-align:center;padding:40px 0}.no-puzzle-state h3{margin-bottom:8px;font-size:1.2rem}.no-puzzle-state p{color:#888;font-size:.9rem;line-height:1.5}.answer-breakdown{text-align:left;border:1.5px solid #e8e8e8;border-radius:16px;width:100%;margin-bottom:24px;overflow:hidden}.answer-breakdown-title{text-transform:uppercase;letter-spacing:.1em;color:#888;background:#fafafa;border-bottom:1px solid #f0f0f0;padding:14px 16px 10px;font-size:.7rem;font-weight:800}.answer-rows{flex-direction:column;display:flex}.answer-row{border-bottom:1px solid #f5f5f5;align-items:baseline;gap:10px;padding:11px 16px;transition:background .12s;display:flex}.answer-row:last-child{border-bottom:none}.answer-row:hover{background:#f9f9f9}.answer-word{letter-spacing:.04em;color:#1a1a1a;flex-shrink:0;min-width:90px;font-size:.88rem;font-weight:800}.answer-desc{color:#777;font-size:.8rem;font-weight:500;line-height:1.4}@media (width<=480px){#app{padding:0}.screen{padding:0 16px}.daily-card{margin-bottom:24px;padding:20px}.stat-chip{padding:10px}.puzzle-header{padding:8px 0 6px}.puzzle-title-text{font-size:1rem}.puzzle-footer{padding:12px 0}.btn{padding:12px 20px;font-size:.9rem}.success-stats{gap:12px;padding:16px 20px}.success-title{font-size:1.6rem}}
