*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--sage: #4a7c6f;--sage-l: #e8f0ed;--sage-m: #b5d0c8;--sage-d: #2d5a50;--warm: #b87333;--warm-l: #fdf3e7;--warm-m: #e8c68a;--rose: #9b5a6a;--rose-l: #f5e8ec;--rose-m: #d4a0ad;--slate: #3d5a73;--slate-l: #e5edf5;--slate-m: #9db8cc;--ink: #1a1a18;--muted: #6b6b68;--hint: #9a9895;--surface: #ffffff;--surface2: #f7f6f2;--surface3: #efede8;--border: rgba(0,0,0,.1);--border-m: rgba(0,0,0,.18);--radius: 10px;--radius-lg:14px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;line-height:1.6;color:var(--ink);background:var(--surface2);-webkit-font-smoothing:antialiased}@media (prefers-color-scheme: dark){:root{--ink: #e8e6df;--muted: #9a9890;--hint: #6b6b68;--surface: #1e1e1c;--surface2: #252523;--surface3: #2e2e2b;--border: rgba(255,255,255,.1);--border-m: rgba(255,255,255,.18)}}h1{font-size:22px;font-weight:500}h2{font-size:18px;font-weight:500}h3{font-size:16px;font-weight:500}p{color:var(--muted)}a{color:var(--sage);text-decoration:none}a:hover{text-decoration:underline}input,textarea{width:100%;font-family:inherit;font-size:14px;padding:.65rem .85rem;border:.5px solid var(--border-m);border-radius:var(--radius);background:var(--surface);color:var(--ink);outline:none;transition:border-color .15s}input:focus,textarea:focus{border-color:var(--sage-m)}input::placeholder,textarea::placeholder{color:var(--hint)}textarea{resize:vertical;min-height:80px;line-height:1.6}button{font-family:inherit;font-size:14px;font-weight:500;padding:.65rem 1.25rem;border-radius:var(--radius);border:.5px solid var(--border-m);background:transparent;color:var(--ink);cursor:pointer;transition:all .18s;line-height:1}button:hover{background:var(--surface3)}button:active{transform:scale(.98)}button:disabled{opacity:.45;cursor:not-allowed;transform:none}button.primary{background:var(--sage);border-color:var(--sage);color:#fff}button.primary:hover{background:var(--sage-d);border-color:var(--sage-d)}button.ghost{border-color:transparent;color:var(--muted)}button.ghost:hover{background:var(--surface3);color:var(--ink)}.card{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:13px;font-weight:500;color:var(--muted)}.field-error{font-size:12px;color:var(--rose);margin-top:2px}.divider{display:flex;align-items:center;gap:.75rem;color:var(--hint);font-size:12px;margin:.5rem 0}.divider:before,.divider:after{content:"";flex:1;height:.5px;background:var(--border)}.alert{font-size:13px;padding:.75rem 1rem;border-radius:var(--radius);line-height:1.6}.alert-error{background:var(--rose-l);color:var(--rose);border:.5px solid var(--rose-m)}.alert-success{background:var(--sage-l);color:var(--sage);border:.5px solid var(--sage-m)}.alert-info{background:var(--slate-l);color:var(--slate);border:.5px solid var(--slate-m)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:18px;height:18px;border:2px solid var(--border-m);border-top-color:var(--sage);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}
