:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--bg: #f6f7fb;--surface: #ffffff;--border: rgba(15, 23, 42, .1);--text-main: #0f172a;--text-muted: #64748b;--accent-1: #8b5cf6;--accent-2: #ec4899;--accent-3: #22d3ee;--primary-soft: rgba(139, 92, 246, .1);--chip-bg: rgba(255, 255, 255, .7);--radius-xl: 22px;--radius-lg: 16px;--radius-md: 12px}*{box-sizing:border-box}body{margin:0;color:var(--text-main);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Arial,sans-serif;background:radial-gradient(700px 320px at 12% -10%,rgba(236,72,153,.14),transparent 60%),radial-gradient(620px 340px at 92% 10%,rgba(139,92,246,.14),transparent 60%),radial-gradient(720px 420px at 50% 105%,rgba(34,211,238,.12),transparent 65%),linear-gradient(180deg,#fbfcff 0%,var(--bg) 100%)}.container{max-width:760px;margin:0 auto;padding:20px 14px 40px}.header{margin-bottom:18px}.header h1{margin:0;font-size:26px;font-weight:850;letter-spacing:-.03em}.sub{margin-top:6px;font-size:14px;color:var(--text-muted)}.chips{display:flex;gap:10px;overflow-x:auto;padding-bottom:6px;margin-bottom:22px}.chip{padding:9px 16px;border-radius:999px;border:1px solid var(--border);background:var(--chip-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;transition:transform .15s ease,background .15s ease,border .15s ease}.chip:hover{transform:translateY(-1px);background:#ffffffd9}.chip.active{background:linear-gradient(135deg,#8b5cf6e6,#ec4899d9);color:#fff;border-color:#fff0}.list{display:grid;gap:18px}.card{background:var(--surface);border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-xl);padding:18px 18px 20px;display:grid;gap:12px;position:relative;box-shadow:0 1px #0f172a08,0 16px 40px #0f172a0f;animation:fadeUp .25s ease both}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.card-header{padding-left:12px;border-left:4px solid transparent;border-image:linear-gradient(180deg,#8b5cf6,#ec4899,#22d3ee) 1}.da{font-size:16px;font-weight:750}.jp{font-size:24px;font-weight:520;letter-spacing:.04em;margin-top:4px}.romaji{font-size:13px;color:var(--text-muted);letter-spacing:.02em}.actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}.btn{border-radius:var(--radius-md);padding:12px;font-size:14px;font-weight:650;cursor:pointer;border:1px solid rgba(15,23,42,.12);background:#ffffffd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:transform .05s ease,box-shadow .12s ease,background .12s ease}.btn:hover{background:#fffffff2;box-shadow:0 10px 22px #0f172a14}.btn:active{transform:translateY(1px);box-shadow:0 6px 14px #0f172a14}.btn.primary{grid-column:span 2;background:linear-gradient(135deg,#8b5cf6f2,#ec4899e6);color:#fff;border:none;box-shadow:0 10px 24px #8b5cf640}.btn.primary:hover{box-shadow:0 14px 30px #8b5cf647}.btn.primary:active{box-shadow:0 8px 18px #8b5cf638}.btn.ghost{background:#f8fafcd9}@media(max-width:420px){.jp{font-size:22px}.container{padding-top:16px}}.topbar{position:sticky;top:12px;z-index:20;margin:18px;border-radius:14px;-webkit-backdrop-filter:blur(8px) saturate(120%);backdrop-filter:blur(8px) saturate(120%);background:linear-gradient(180deg,#ffffffe0,#fafafab3);box-shadow:0 6px 30px #10182814;padding:8px 0}.topbar-inner{display:flex;align-items:center;gap:12px;justify-content:space-between}.menu-button{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(90deg,#8b5cf61f,#ec48991a);border:none;padding:8px 10px;border-radius:10px;font-size:18px;cursor:pointer;box-shadow:0 6px 18px #0f172a0f}.tabs{display:flex;gap:8px}.tab{background:transparent;border:none;padding:8px 14px;border-radius:10px;font-weight:800;color:var(--text-main);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}.tab:hover{transform:translateY(-2px)}.tab.active{color:#fff;background:linear-gradient(90deg,var(--accent-1),var(--accent-2));box-shadow:0 10px 24px #8b5cf62e}.mobile-menu{margin:10px 14px 16px;padding:12px;display:flex;gap:8px;background:#fffffffa;border-radius:12px;box-shadow:0 8px 30px #0f172a0f;flex-direction:column}.desktop-only{display:flex}.mobile-only{display:none}@media(max-width:720px){.desktop-only{display:none}.mobile-only{display:inline-flex}.topbar{margin:12px}.brand{margin-left:8px;flex:1}}.card{border-radius:18px;padding:18px}.btn.primary{padding:14px;border-radius:12px;font-weight:800}.btn.ghost{background:#fff;box-shadow:0 6px 18px #0f172a0a}.phrases .container{max-width:760px;margin:0 auto;padding:20px 14px 40px}.phrases .header{margin-bottom:18px}.phrases .header h1{margin:0;font-size:26px;font-weight:850;letter-spacing:-.03em}.phrases .sub{margin-top:6px;font-size:14px;color:var(--text-muted)}.phrases .chips{display:flex;gap:10px;overflow-x:auto;padding-bottom:6px;margin-bottom:22px}.phrases .chip{padding:9px 16px;border-radius:999px;border:1px solid var(--border);background:var(--chip-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;transition:transform .15s ease,background .15s ease,border .15s ease}.phrases .chip:hover{transform:translateY(-1px);background:#ffffffd9}.phrases .chip.active{background:linear-gradient(135deg,#8b5cf6e6,#ec4899d9);color:#fff;border-color:#fff0}.phrases .list{display:grid;gap:18px}.phrases .card{background:var(--surface);border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-xl);padding:18px 18px 20px;display:grid;gap:12px;position:relative;box-shadow:0 1px #0f172a08,0 16px 40px #0f172a0f;animation:phrasesFadeUp .25s ease both}@keyframes phrasesFadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.phrases .card-header{padding-left:12px;border-left:4px solid transparent;border-image:linear-gradient(180deg,#8b5cf6,#ec4899,#22d3ee) 1}.phrases .da{font-size:16px;font-weight:750}.phrases .jp{font-size:24px;font-weight:520;letter-spacing:.04em;margin-top:4px}.phrases .romaji{font-size:13px;color:var(--text-muted);letter-spacing:.02em}.phrases .actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}.phrases .btn{border-radius:var(--radius-md);padding:12px;font-size:14px;font-weight:650;cursor:pointer;border:1px solid rgba(15,23,42,.12);background:#ffffffd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:transform .05s ease,box-shadow .12s ease,background .12s ease}.phrases .btn:hover{background:#fffffff2;box-shadow:0 10px 22px #0f172a14}.phrases .btn:active{transform:translateY(1px);box-shadow:0 6px 14px #0f172a14}.phrases .btn.primary{grid-column:span 2;background:linear-gradient(135deg,#8b5cf6f2,#ec4899e6);color:#fff;border:none;box-shadow:0 10px 24px #8b5cf640}.phrases .btn.primary:hover{box-shadow:0 14px 30px #8b5cf647}.phrases .btn.primary:active{box-shadow:0 8px 18px #8b5cf638}.phrases .btn.ghost{background:#f8fafcd9}@media(max-width:420px){.phrases .jp{font-size:22px}.phrases .container{padding-top:16px}}.restaurants .container{max-width:760px;margin:0 auto;padding:20px 14px 40px}.restaurants h2{margin:0;font-size:20px;font-weight:850;letter-spacing:-.02em}.restaurants .sub{margin-top:6px;font-size:14px;color:var(--text-muted)}.restaurants .controls{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:14px}.restaurants .chip{padding:9px 14px;border-radius:999px;border:1px solid var(--border);background:var(--chip-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-size:14px;font-weight:600;cursor:pointer}.restaurants .card{background:var(--surface);border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-xl);padding:16px 16px 18px;display:grid;gap:10px;box-shadow:0 1px #0f172a08,0 14px 32px #0f172a0f;animation:restaurantsFadeUp .25s ease both}@keyframes restaurantsFadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.restaurants .card.selected{border-color:#8b5cf659;box-shadow:0 1px #0f172a08,0 18px 40px #8b5cf62e}.restaurants .restaurant-name{font-size:16px;font-weight:800}.restaurants .summary{font-size:13px;color:var(--text-muted);line-height:1.45}.restaurants .actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}.restaurants .btn{border-radius:var(--radius-md);padding:11px;font-size:14px;font-weight:650;cursor:pointer;border:1px solid rgba(15,23,42,.12);background:#ffffffd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:transform .05s ease,box-shadow .12s ease,background .12s ease}.restaurants .btn:hover{background:#fffffff2;box-shadow:0 10px 22px #0f172a14}.restaurants .btn:active{transform:translateY(1px)}.restaurants .btn.primary{grid-column:span 2;background:linear-gradient(135deg,#22d3eef2,#8b5cf6f2);color:#fff;border:none;box-shadow:0 10px 24px #22d3ee47}.restaurants .btn.primary:hover{box-shadow:0 14px 30px #22d3ee52}.restaurants .list{display:grid;gap:14px;margin-top:16px}.restaurants .list .card{cursor:pointer}@media(max-width:420px){.restaurants h2{font-size:18px}.restaurants .container{padding-top:16px}}
