:root{--bg-primary:#09090b;--bg-secondary:#18181b;--bg-tertiary:#27272a;--bg-surface:#18181bb3;--text-primary:#fafafa;--text-secondary:#a1a1aa;--text-tertiary:#71717a;--accent-primary:#3b82f6;--accent-hover:#2563eb;--accent-active:#1d4ed8;--danger:#ef4444;--success:#22c55e;--border-color:#3f3f46;--border-light:#ffffff1a;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--shadow-glow:0 0 15px #3b82f64d;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-full:9999px;--font-sans:"Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-normal:.25s cubic-bezier(.4, 0, .2, 1);--transition-bounce:.4s cubic-bezier(.34, 1.56, .64, 1)}@media (prefers-color-scheme:light){:root{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-tertiary:#f1f5f9;--bg-surface:#fffc;--text-primary:#0f172a;--text-secondary:#475569;--text-tertiary:#94a3b8;--border-color:#e2e8f0;--border-light:#0000000d}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;min-height:100%;font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;overflow-x:hidden}#root{width:100%;min-height:100%}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input,textarea{color:inherit;font-family:inherit}.glass{background:var(--bg-surface);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-light)}.hide-scrollbar::-webkit-scrollbar{display:none}.hide-scrollbar{-ms-overflow-style:none;scrollbar-width:none}:root{--rl-bg:#f7f8f7;--rl-panel:#fff;--rl-ink:#182025;--rl-muted:#6b747b;--rl-line:#dfe5e2;--rl-line-strong:#c8d1cd;--rl-teal:#08766f;--rl-teal-dark:#075f59;--rl-danger:#a73535;--rl-shadow:0 16px 40px #1820251a;font-family:Avenir Next,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif}.rl-app{min-height:100vh;color:var(--rl-ink);background:var(--rl-bg)}.rl-header{z-index:8;border-bottom:1px solid var(--rl-line);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#f7f8f7f0;justify-content:space-between;align-items:center;gap:12px;height:64px;padding:0 24px;display:flex;position:sticky;top:0}.rl-header h1,.rl-panel-header h2,.rl-empty h2{letter-spacing:0;margin:0}.rl-header h1{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:24px;line-height:1.1;overflow:hidden}.rl-header-actions,.rl-form-actions,.rl-detail-actions{align-items:center;gap:8px;display:flex}.rl-primary-button,.rl-secondary-button,.rl-danger-button,.rl-icon-button{border-radius:8px;justify-content:center;align-items:center;gap:7px;min-height:40px;font-weight:750;display:inline-flex}.rl-primary-button{background:var(--rl-teal);color:#fff;padding:0 14px}.rl-primary-button:hover{background:var(--rl-teal-dark)}.rl-primary-button:disabled,.rl-danger-button:disabled{cursor:not-allowed;opacity:.65}.rl-secondary-button,.rl-danger-button,.rl-icon-button{border:1px solid var(--rl-line);background:var(--rl-panel);color:var(--rl-ink)}.rl-danger-button{color:var(--rl-danger)}.rl-icon-button{width:40px;padding:0}.rl-main{grid-template-columns:minmax(0,1fr) minmax(360px,420px);gap:20px;width:min(1160px,100%);margin:0 auto;padding:18px 24px 32px;display:grid}.rl-main-detail-open{grid-template-columns:minmax(320px,420px) minmax(0,720px);width:min(1180px,100%)}.rl-library{min-width:0}.rl-search-row{border:1px solid var(--rl-line-strong);background:var(--rl-panel);border-radius:8px;align-items:center;gap:10px;height:56px;padding:0 14px;display:flex}.rl-search-row:focus-within{border-color:var(--rl-teal);box-shadow:0 0 0 3px #08766f1a}.rl-search-row svg{color:var(--rl-teal);flex:none}.rl-search-row input{width:100%;min-width:0;color:var(--rl-ink);background:0 0;border:0;outline:0;font-size:18px}.rl-search-row input::placeholder{color:#9aa3a8}.rl-list{gap:8px;margin-top:12px;display:grid}.rl-recipe-row{border:1px solid var(--rl-line);background:var(--rl-panel);min-height:72px;color:var(--rl-ink);text-align:left;border-radius:8px;justify-content:space-between;align-items:center;gap:14px;padding:10px 14px;display:flex}.rl-recipe-row:hover{border-color:var(--rl-teal)}.rl-recipe-main{gap:5px;min-width:0;display:grid}.rl-recipe-title{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:17px;font-weight:700;line-height:1.35;overflow:hidden}.rl-recipe-note{min-width:0;color:var(--rl-muted);text-overflow:ellipsis;white-space:nowrap;font-size:14px;line-height:1.4;overflow:hidden}.rl-recipe-note-empty{color:#a0a8ad}.rl-recipe-time{color:var(--rl-muted);white-space:nowrap;flex:none;font-size:13px;line-height:1.2}.rl-grid-state,.rl-empty{border:1px dashed var(--rl-line-strong);background:var(--rl-panel);min-height:180px;color:var(--rl-muted);text-align:center;border-radius:8px;place-items:center;margin-top:12px;display:grid}.rl-empty{gap:14px;padding:24px}.rl-empty h2{color:var(--rl-muted);font-size:20px;font-weight:700}.rl-grid-state--error{color:var(--rl-danger)}.rl-detail,.rl-form-panel{border:1px solid var(--rl-line);background:var(--rl-panel);box-shadow:var(--rl-shadow);border-radius:8px}.rl-detail{max-height:calc(100vh - 100px);padding:16px;position:sticky;top:82px;overflow:auto}.rl-detail-topbar,.rl-panel-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.rl-detail-topbar{z-index:2;border-bottom:1px solid var(--rl-line);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff0;margin:-16px -16px 0;padding:12px 16px;position:sticky;top:-16px}.rl-panel-header h2{font-size:22px;line-height:1.2}.rl-detail-heading{padding:18px 0 14px}.rl-detail-heading h2{letter-spacing:0;margin:0;font-size:24px;line-height:1.25}.rl-detail-heading span{color:var(--rl-muted);margin-top:8px;font-size:13px;display:inline-flex}.rl-kicker,.rl-detail-count{display:none}.rl-detail-actions{margin:0}.rl-detail-meta{border-top:1px solid var(--rl-line);background:#fbfcfb;border-radius:8px;margin-top:14px;padding:14px}.rl-detail-meta span{color:var(--rl-muted);margin-bottom:6px;font-size:13px;font-weight:750;display:block}.rl-detail-meta p{color:var(--rl-ink);white-space:pre-wrap;margin:0;line-height:1.65}.rl-image-stack{gap:14px;display:grid}.rl-image-stack figure{border:1px solid var(--rl-line);background:#f3f5f4;border-radius:8px;margin:0;overflow:hidden}.rl-image-stack img{background:#f3f5f4;width:100%;height:auto;display:block}.rl-image-stack figcaption{color:var(--rl-muted);padding:8px 10px;font-size:12px}.rl-modal-backdrop{z-index:20;background:#18202575;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.rl-form-panel{width:min(760px,100%);max-height:min(820px,100vh - 32px);padding:0;overflow:auto}.rl-form{gap:14px;margin:0;display:grid}.rl-form-panel .rl-panel-header{border-bottom:1px solid var(--rl-line);padding:18px 20px}.rl-form-body{grid-template-columns:minmax(0,1fr) 260px;gap:18px;padding:20px;display:grid}.rl-form-fields,.rl-image-section{align-content:start;gap:14px;display:grid}.rl-login-screen{background:linear-gradient(135deg, #08766f14, transparent 36%), linear-gradient(315deg, #a735350f, transparent 34%), var(--rl-bg);place-items:center;min-height:100vh;padding:24px;display:grid}.rl-login-card{border:1px solid var(--rl-line);width:min(400px,100%);box-shadow:var(--rl-shadow);background:#fffffff5;border-radius:8px;padding:28px}.rl-login-card--status{text-align:center}.rl-login-brand{text-align:center;justify-items:center;gap:10px;display:grid}.rl-login-mark{width:48px;height:48px;color:var(--rl-teal);background:#edf7f4;border:1px solid #cde1dc;border-radius:8px;justify-content:center;align-items:center;display:inline-flex}.rl-login-brand h1{letter-spacing:0;margin:0;font-size:30px;line-height:1.1}.rl-login-brand p{color:var(--rl-muted);margin:0;line-height:1.5}.rl-login-form{gap:14px;margin-top:26px;display:grid}.rl-login-field{gap:8px}.rl-login-field input{background:#fff;height:48px}.rl-login-submit{width:100%;min-height:46px;margin-top:4px}.rl-login-status{color:var(--rl-muted);margin:22px 0 0;font-weight:700}.rl-field{gap:7px;display:grid}.rl-field span{color:var(--rl-muted);font-size:13px;font-weight:750}.rl-field input,.rl-field textarea{border:1px solid var(--rl-line);width:100%;color:var(--rl-ink);background:#fbfcfb;border-radius:8px;outline:0;font-size:16px}.rl-field input{height:44px;padding:0 12px}.rl-field textarea{resize:vertical;padding:12px;line-height:1.55}.rl-field input:focus,.rl-field textarea:focus{border-color:var(--rl-teal);box-shadow:0 0 0 3px #08766f1a}.rl-upload-zone{min-height:172px;color:var(--rl-teal);cursor:pointer;text-align:center;background:#f6faf8;border:1px dashed #98aaa4;border-radius:8px;place-items:center;gap:8px;padding:18px;display:grid}.rl-upload-zone:hover{border-color:var(--rl-teal);background:#f1f8f6}.rl-upload-icon{background:#e7f3ef;border-radius:8px;justify-content:center;align-items:center;width:44px;height:44px;display:inline-flex}.rl-upload-zone span{font-weight:800}.rl-upload-zone small{color:var(--rl-muted)}.rl-upload-zone input{display:none}.rl-preview-block{gap:10px;display:grid}.rl-preview-header{color:var(--rl-muted);justify-content:space-between;align-items:center;gap:8px;font-size:12px;font-weight:750;display:flex}.rl-preview-header small{font-weight:650}.rl-existing-images{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.rl-existing-images img{aspect-ratio:4/3;border:1px solid var(--rl-line);object-fit:cover;border-radius:8px;width:100%}.rl-form-error{color:var(--rl-danger);margin:0;font-weight:750}.rl-form>.rl-form-error{margin:-4px 20px 0}.rl-form>.rl-form-actions{border-top:1px solid var(--rl-line);background:#fbfcfb;justify-content:flex-end;padding:14px 20px}.rl-confirm-copy{color:var(--rl-muted);margin:18px 0;line-height:1.65}.rl-delete-panel{border:1px solid var(--rl-line);background:var(--rl-panel);width:min(430px,100%);box-shadow:var(--rl-shadow);border-radius:8px;padding:18px}.rl-delete-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.rl-delete-icon{width:44px;height:44px;color:var(--rl-danger);background:#fff1f1;border-radius:8px;justify-content:center;align-items:center;display:inline-flex}.rl-delete-copy{margin-top:16px}.rl-delete-copy h2{letter-spacing:0;margin:0;font-size:24px;line-height:1.2}.rl-delete-copy p{color:var(--rl-muted);margin:12px 0 0;line-height:1.6}.rl-delete-name{word-break:break-word;background:#fff8f8;border:1px solid #f0d6d6;border-radius:8px;padding:10px 12px;font-weight:750;color:var(--rl-ink)!important}.rl-delete-actions{justify-content:flex-end;gap:10px;margin-top:22px;display:flex}@media (width<=860px){.rl-header{height:56px;padding:0 12px}.rl-header h1{font-size:21px}.rl-primary-button{padding:0 12px}.rl-login-screen{padding:14px}.rl-login-card{padding:24px 18px}.rl-login-brand h1{font-size:28px}.rl-main{width:100%;padding:12px;display:block}.rl-search-row{height:52px}.rl-search-row input{font-size:17px}.rl-list{gap:7px}.rl-recipe-row{flex-direction:column;align-items:stretch;gap:6px;min-height:76px}.rl-recipe-title{font-size:16px}.rl-recipe-note{font-size:13px}.rl-recipe-time{align-self:flex-end;font-size:12px}.rl-empty,.rl-grid-state{min-height:150px}.rl-detail{z-index:18;max-height:none;box-shadow:none;border:0;border-radius:0;padding:0 14px 18px;position:fixed;inset:0;overflow:auto}.rl-detail-topbar{margin:0 -14px;padding:10px 14px;top:0}.rl-back-button{padding:0 10px}.rl-detail-actions{gap:6px}.rl-detail-actions .rl-secondary-button,.rl-detail-actions .rl-danger-button{padding:0 10px}.rl-detail-heading{padding:16px 0 12px}.rl-detail-heading h2{font-size:22px}.rl-detail-meta{margin-top:12px}.rl-delete-panel{width:100%;padding:16px 14px calc(14px + env(safe-area-inset-bottom));border-bottom:0;border-left:0;border-right:0;border-radius:8px 8px 0 0}.rl-delete-copy h2{font-size:22px}.rl-delete-actions{margin-top:18px}.rl-delete-actions .rl-secondary-button,.rl-delete-actions .rl-danger-button{flex:1;min-height:44px}.rl-modal-backdrop{align-items:stretch;padding:0}.rl-delete-backdrop{place-items:end stretch;padding:0}.rl-form-panel{border:0;border-radius:0;width:100%;max-height:100vh}.rl-form{grid-template-rows:1fr auto;min-height:calc(100vh - 69px)}.rl-form-panel .rl-panel-header{z-index:2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff5;padding:14px;position:sticky;top:0}.rl-form-body{grid-template-columns:1fr;gap:16px;padding:14px 14px 18px}.rl-field input{height:46px}.rl-field textarea{min-height:132px}.rl-upload-zone{min-height:136px}.rl-existing-images{grid-template-columns:1fr 1fr}.rl-form>.rl-form-error{margin:-6px 14px 0}.rl-form>.rl-form-actions{padding:10px 14px calc(10px + env(safe-area-inset-bottom));position:sticky;bottom:0}.rl-form>.rl-form-actions .rl-secondary-button,.rl-form>.rl-form-actions .rl-primary-button{flex:1;min-height:44px}}@media (width<=380px){.rl-header-actions{gap:6px}.rl-icon-button{width:38px}.rl-primary-button{min-height:38px;padding:0 10px}.rl-existing-images{gap:8px}}
