:root{--app-height: 100dvh;--bg-1: #fff1f6;--bg-2: #ffffff;--bg-3: #f5f7ff;--card: #ffffff;--text: #13141b;--muted: #6b6f81;--line: #e7e9f2;--line-soft: #f0f1f7;--primary: #0f1115;--primary-text: #ffffff;--secondary: #f2f3f7;--secondary-text: #262a38;--chip: #f8f9fc;--danger: #be123c;--success-bg: #ecfdf3;--success-text: #116534}*{box-sizing:border-box}html,body,#root{width:100%;height:100%}body{margin:0;min-height:var(--app-height);color:var(--text);font-family:Manrope,Nunito Sans,Segoe UI,sans-serif;background:radial-gradient(circle at 10% 5%,var(--bg-1) 0%,transparent 40%),radial-gradient(circle at 90% 95%,#f2f7ff 0%,transparent 38%),linear-gradient(145deg,var(--bg-2) 0%,var(--bg-3) 100%)}.app{min-height:var(--app-height);width:100%;display:block;padding:0}.phone-card{width:100%;min-height:0;display:block;border-radius:0;background:var(--card);border:0;box-shadow:none;overflow:hidden}.topline{display:flex;justify-content:space-between;gap:12px;padding:16px 14px 10px;border-bottom:1px solid var(--line-soft);background:linear-gradient(160deg,#fff3f8,#fff 55%)}.brand{display:flex;gap:10px;align-items:center}.brand-icon{width:34px;height:34px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(145deg,#e11d7b,#be185d);color:#fff;box-shadow:0 8px 18px #be185d4d}.brand strong{display:block;font-size:15px;line-height:1.1}.brand span{display:block;color:var(--muted);font-size:12px;margin-top:2px}.screen-head{padding:12px 14px 0}.screen-badge{display:inline-block;padding:5px 10px;border-radius:999px;background:#ffe8f2;color:#be185d;font-size:12px;font-weight:700;margin-bottom:10px}.screen-head h1{margin:0;font-size:39px;line-height:1.08;letter-spacing:-.03em}.screen-head p{margin:10px 0 0;color:var(--muted);line-height:1.5;font-size:15px}.screen-body{padding:14px 14px calc(14px + env(safe-area-inset-bottom));animation:bodyIn .22s ease-out}.lang-switch{display:inline-flex;gap:6px;align-items:center}.lang-switch button{width:auto;min-width:40px;padding:6px 10px;border-radius:10px;border:1px solid var(--line);background:#fff;color:var(--secondary-text);cursor:pointer}.lang-switch button.is-active{background:var(--primary);color:var(--primary-text);border-color:var(--primary)}.stack{display:grid;gap:10px}.stack-welcome{min-height:clamp(480px,calc(var(--app-height) - 260px),820px)}.info-box{border-radius:18px;border:1px solid var(--line);background:#fcfdff;padding:12px}.info-box p{margin:6px 0;line-height:1.45}.popular-section{margin-top:auto;border-radius:18px;border:1px solid var(--line);background:#fff9fc;padding:12px;text-align:center}.popular-section h3{margin:0 0 10px;font-size:15px;line-height:1.3}.popular-section .chips{justify-content:center}.share-link{border:1px dashed #f0a3c7;border-radius:12px;padding:10px 12px;color:#9d174d;background:#fff;font-weight:600;overflow-wrap:anywhere}button,input,textarea,select{width:100%;border-radius:15px;border:1px solid var(--line);padding:13px 14px;font:inherit;color:var(--text);background:#fff;transition:border-color .18s ease,box-shadow .18s ease}textarea{min-height:92px;resize:vertical}input,textarea{caret-color:var(--primary)}input:focus,textarea:focus,select:focus{outline:none;border-color:#111827;box-shadow:0 0 0 3px #1118271a}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.45}.primary{border:none;background:var(--primary);color:var(--primary-text);font-weight:700;min-height:52px}.secondary{border:1px solid #e6e8f2;background:var(--secondary);color:var(--secondary-text);font-weight:600;min-height:50px}.ghost{border:1px solid var(--line);background:#fff;color:#575d6f;min-height:48px}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{width:auto;border-radius:999px;background:var(--chip);border:1px solid var(--line);color:#34384a;padding:8px 12px;font-size:13px}.quick-templates{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.quick-templates .chip{width:100%;text-align:center;justify-content:center;padding:10px 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.template-catalog{border-radius:18px;border:1px solid var(--line);background:#fcfdff;padding:12px}.template-catalog-title{margin:0 0 10px;color:var(--muted);font-size:13px}.template-catalog-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.template-item{width:100%;min-height:46px;border-radius:12px;border:1px solid var(--line);background:#fff;color:#2f3446;text-align:left;padding:10px 12px;font-weight:600}.hint-editor-card{border:1px solid var(--line);border-radius:16px;background:#fcfdff;padding:10px;display:grid;gap:8px}.hint-editor-title{font-size:13px;color:var(--muted);font-weight:700}.hint-text-input{min-height:48px;max-height:180px;resize:none;overflow-y:hidden;line-height:1.45;white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word}.hint-editor-actions{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:8px}.hint-editor-actions select,.hint-editor-actions button{min-height:44px}.hint-photo-preview{display:grid;gap:8px;border:1px solid var(--line);border-radius:12px;background:#fff;padding:8px}.hint-photo-preview img{width:100%;height:auto;max-height:130px;object-fit:contain;background:#fff;border-radius:10px}.hint-photo-meta{display:flex;align-items:center;gap:8px}.hint-photo-meta-text{flex:1;min-width:0}.hint-photo-meta-text span{display:block;color:#464b5f;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hint-photo-meta-text small{display:block;margin-top:2px;font-size:11px;color:var(--muted)}.hint-photo-meta .ghost{width:auto;min-height:38px;padding:8px 10px}.progress-track{margin-top:10px;height:8px;border-radius:999px;background:#e8ebf3;overflow:hidden}.progress-track-guess{margin-top:0;background:#ffffff80}.progress-fill{height:100%;border-radius:999px;background:#0f1115}.helper{margin:0;color:var(--muted);font-size:13px;line-height:1.5}.error{margin:0;color:var(--danger);font-size:13px}.hint-row{margin:0;padding:10px 12px;border:1px solid #ffd5e5;border-radius:12px;background:#fff7fb;color:#9d174d}.hint-row-photo p{margin:0 0 8px}.hint-row-photo img{width:100%;height:auto;max-height:220px;object-fit:contain;background:#fff;border-radius:10px;border:1px solid #f8bbd8}.guess-hints-panel{border-radius:22px;padding:14px;border:1px solid #ffd7e6;background:radial-gradient(circle at top left,#fffffff2,#ffffffa6),linear-gradient(145deg,#fff4f8,#ffe8f1);box-shadow:0 16px 30px #e3709c1f}.guess-layout{display:grid;gap:14px}.guess-hints-panel-current{padding-bottom:12px}.guess-hints-panel-queue{padding-top:12px;background:radial-gradient(circle at top left,#ffffffe6,#fff9),linear-gradient(145deg,#f8faff,#f3f6fb);border-color:#e3e8f3;box-shadow:0 14px 28px #525f7f14}.guess-hint-current-slot{margin-top:12px}.guess-hints-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.guess-hints-kicker{font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#be185d}.guess-hints-count{min-width:52px;padding:5px 10px;border-radius:999px;background:#ffffffd9;border:1px solid rgba(240,163,199,.7);color:#9d174d;font-size:12px;font-weight:800;text-align:center}.guess-hints-list{margin-top:12px;display:grid;gap:10px;padding-bottom:4px}.guess-hints-list-queue{margin-top:0}.guess-hint-card{border-radius:18px;border:1px solid rgba(243,188,213,.95);background:#ffffffe6;padding:12px;box-shadow:0 10px 24px #be185d0f}.guess-hint-card.is-latest{border-color:#f0a3c7;background:linear-gradient(145deg,#fff,#fff5fa);box-shadow:0 14px 28px #be185d1f}.guess-hint-card-final{border-color:#fbbf24d9;background:linear-gradient(145deg,#fffdf6,#fff7e1);box-shadow:0 14px 28px #f59e0b1f}.guess-hint-card-locked{border-style:dashed;border-color:#ced5e2f2;background:linear-gradient(145deg,#fafbfff2,#f3f5fafa);box-shadow:none}.guess-hint-label{display:flex;align-items:center;gap:8px;margin-bottom:8px;color:#9d174d;font-size:12px;font-weight:800}.guess-hint-index{width:24px;height:24px;display:inline-grid;place-items:center;border-radius:999px;background:#be185d;color:#fff;font-size:12px;line-height:1}.guess-hint-index-locked{background:#c7ccda;color:#fff}.guess-hint-value{color:#2c3142;font-size:17px;line-height:1.45;font-weight:700;overflow-wrap:anywhere;word-break:break-word}.guess-hint-locked-value{min-height:54px;display:flex;align-items:center;justify-content:center;gap:8px;border-radius:14px;background:linear-gradient(135deg,#ffffffb3,#f0f3f8f2);color:#8a90a3;font-size:15px;font-weight:700}.guess-hint-lock{font-size:16px;line-height:1}.guess-hint-card-photo .guess-hint-photo-wrap{border-radius:14px;overflow:hidden;border:1px solid #f7c1d9;background:#fffffff2;padding:8px}.guess-hint-card-photo img{width:100%;height:auto;max-height:220px;object-fit:contain;display:block;border-radius:10px}.guess-composer{display:grid;gap:10px;padding:12px;border-radius:22px;border:1px solid rgba(232,235,243,.98);background:linear-gradient(180deg,#fffffffa,#f9fafdfa);box-shadow:0 14px 32px #13141b14}.guess-composer .helper,.guess-composer .error{padding-inline:2px}.guess-end-actions{display:grid;gap:10px;padding-top:4px}.guess-final-inline{margin-bottom:2px}.guess-end-title{margin:0;color:#6b7280;font-size:14px;line-height:1.45}.wish-row{margin:0;padding:12px;border:1px solid #c4f3d3;border-radius:12px;background:var(--success-bg);color:var(--success-text);font-weight:700}.history-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.history-toolbar label{color:var(--muted);font-size:13px}.history-toolbar select{width:auto;min-width:140px;background:#fff}.history-item{border:1px solid var(--line);border-radius:16px;background:#fcfdff;padding:12px}.history-item-focused{border-color:#f0a3c7;background:linear-gradient(145deg,#fffefe,#fff5fa);box-shadow:0 0 0 3px #f0a3c72e,0 16px 28px #be185d14}.history-item h3{margin:0 0 8px;font-size:17px;line-height:1.35}.history-item p{margin:4px 0;line-height:1.45}.history-date{color:var(--muted);font-size:12px}.history-fulfillment-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:10px}.history-fulfillment-btn{min-height:42px;border-radius:12px;border:1px solid var(--line);background:#fff;font-weight:700}.history-fulfillment-btn-done{color:#166534;border-color:#bbf7d0;background:#f0fdf4}.history-fulfillment-btn-done.is-active{color:#fff;border-color:#15803d;background:#16a34a}.history-fulfillment-btn-not-done{color:#b91c1c;border-color:#fecaca;background:#fef2f2}.history-fulfillment-btn-not-done.is-active{color:#fff;border-color:#dc2626;background:#ef4444}.history-delete{width:100%;margin-top:10px}.status-badge{display:inline-block;border-radius:999px;padding:2px 8px;font-size:12px;font-weight:700;border:1px solid transparent}.status-active{color:#1d4ed8;background:#eff6ff;border-color:#bfdbfe}.status-guessed{color:#065f46;background:#ecfdf5;border-color:#a7f3d0}.status-decided{color:#7c2d12;background:#fff7ed;border-color:#fed7aa}.status-archived{color:#374151;background:#f3f4f6;border-color:#d1d5db}@keyframes bodyIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@supports not (height: 100dvh){:root{--app-height: 100vh}}@media(min-width:900px){.app{display:grid;place-items:center;padding:18px 12px}.phone-card{width:min(420px,100%);min-height:min(880px,calc(var(--app-height) - 36px));display:flex;flex-direction:column;border-radius:34px;border:1px solid var(--line);box-shadow:0 18px 60px #191d301f,0 2px 6px #191d3014}.screen-body{flex:1;padding:14px}}@media(max-width:460px){.stack-welcome{min-height:clamp(440px,calc(var(--app-height) - 230px),780px)}.quick-templates .chip{font-size:13px;padding:9px 6px}.screen-head h1{font-size:35px}}
