: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-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}.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 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-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}}
