*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#f8f9fa;--color-surface:#fff;--color-primary:#2563eb;--color-primary-hover:#1d4ed8;--color-danger:#dc2626;--color-danger-hover:#b91c1c;--color-text:#1f2937;--color-text-muted:#6b7280;--color-border:#e5e7eb;--color-tag:#e0e7ff;--color-tag-active:#2563eb;--radius:8px;--shadow:0 1px 3px #0000001a}body{background:var(--color-bg);color:var(--color-text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}.btn{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);cursor:pointer;align-items:center;gap:4px;padding:8px 16px;font-size:.875rem;transition:background .15s;display:inline-flex}.btn:hover{background:var(--color-bg)}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover{background:var(--color-primary-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-danger{color:var(--color-danger);border-color:var(--color-danger)}.btn-danger:hover{background:#fef2f2}.btn-small{padding:4px 10px;font-size:.8rem}.loading,.empty-state{text-align:center;color:var(--color-text-muted);padding:3rem 1rem}.navbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:10;align-items:center;gap:16px;padding:12px 24px;display:flex;position:sticky;top:0}.nav-brand{color:var(--color-text);font-size:1.2rem;font-weight:700}.nav-brand:hover{text-decoration:none}.nav-links{gap:12px;display:flex}.nav-links a{border-radius:var(--radius);padding:4px 8px;font-size:.9rem}.nav-links a.active{background:var(--color-tag);font-weight:600}.nav-user{align-items:center;gap:10px;margin-left:auto;display:flex}.avatar{border-radius:50%;width:32px;height:32px}.user-name{color:var(--color-text-muted);font-size:.85rem}.main-content{max-width:900px;margin:0 auto;padding:24px 16px}.login-page{justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{text-align:center;background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:3rem}.login-card h1{margin-bottom:.5rem;font-size:2rem}.login-card p{color:var(--color-text-muted);margin-bottom:1.5rem}.list-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.search-input{border:1px solid var(--color-border);border-radius:var(--radius);width:100%;margin-bottom:12px;padding:10px 14px;font-size:1rem}.search-input:focus{outline:2px solid var(--color-primary);border-color:#0000}.tag-filters{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.tag-chip{background:var(--color-tag);color:var(--color-primary);cursor:pointer;border:1px solid #0000;border-radius:999px;align-items:center;gap:4px;padding:4px 12px;font-size:.8rem;transition:all .15s;display:inline-flex}.tag-chip:hover{border-color:var(--color-primary)}.tag-chip.active{background:var(--color-tag-active);color:#fff}.tag-chip.clear{border:1px dashed var(--color-border);color:var(--color-text-muted);background:0 0}.tag-chip.small{cursor:default;padding:2px 8px;font-size:.75rem}.tag-chip.suggestion{border:1px dashed var(--color-border);color:var(--color-text-muted);cursor:pointer;background:0 0}.tag-chip.suggestion:hover{border-color:var(--color-primary);color:var(--color-primary)}.tag-remove{color:inherit;cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:1rem;line-height:1}.recipe-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.recipe-card{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);color:var(--color-text);flex-direction:column;transition:box-shadow .15s;display:flex;overflow:hidden}.recipe-card:hover{text-decoration:none;box-shadow:0 4px 12px #0000001f}.recipe-card-img{object-fit:cover;width:100%;height:160px}.recipe-card-body{flex:1;padding:14px}.recipe-card-body h3{margin-bottom:4px;font-size:1rem}.recipe-card-desc{color:var(--color-text-muted);margin-bottom:8px;font-size:.85rem}.recipe-card-tags{flex-wrap:wrap;gap:4px;display:flex}.recipe-detail{max-width:700px}.detail-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.detail-actions{gap:8px;display:flex}.back-link{font-size:.9rem}.detail-tags{flex-wrap:wrap;gap:6px;margin:8px 0 16px;display:flex}.source-link{font-size:.9rem}.recipe-detail section{margin-top:24px}.recipe-detail h2{border-bottom:1px solid var(--color-border);margin-bottom:8px;padding-bottom:4px;font-size:1.2rem}.ingredient-list{padding-left:20px}.ingredient-list li{padding:2px 0}.text-muted{color:var(--color-text-muted);font-style:italic}.detail-images{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px;margin-bottom:16px;display:grid}.detail-images.single{grid-template-columns:1fr}.detail-images img{object-fit:cover;border-radius:var(--radius);cursor:pointer;width:100%;max-height:400px;transition:opacity .15s}.detail-images img:hover{opacity:.85}.lightbox{z-index:1000;background:#000000e6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.lightbox-image{object-fit:contain;border-radius:4px;max-width:90vw;max-height:90vh}.lightbox-close{color:#fff;cursor:pointer;background:0 0;border:none;font-size:2rem;line-height:1;position:absolute;top:16px;right:16px}.lightbox-nav{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:4px;padding:12px 16px;font-size:2rem;position:absolute;top:50%;transform:translateY(-50%)}.lightbox-nav:hover{background:#ffffff4d}.lightbox-prev{left:16px}.lightbox-next{right:16px}.recipe-body{line-height:1.6}.recipe-body h2{border-bottom:1px solid var(--color-border);margin:20px 0 8px;padding-bottom:4px;font-size:1.2rem}.recipe-body h3{margin:16px 0 6px;font-size:1.05rem}.recipe-body p{margin:8px 0}.recipe-body ul,.recipe-body ol{margin:8px 0;padding-left:24px}.recipe-body li{padding:2px 0}.recipe-body strong{font-weight:600}.admin-panel{max-width:700px}.admin-panel h1{margin-bottom:8px}.admin-panel h2{margin:20px 0 6px;font-size:1.1rem}.orphan-card{border:1px solid var(--color-border);border-radius:var(--radius);margin-top:12px;padding:12px}.orphan-header{align-items:center;gap:12px;margin-bottom:8px;display:flex}.orphan-header code{font-size:.85rem}.orphan-images{flex-wrap:wrap;gap:8px;display:flex}.orphan-images img{object-fit:cover;border-radius:4px;width:100px;height:100px}.recipe-form-page{max-width:700px}.recipe-form-page h1,.import-section{margin-bottom:16px}.import-section h2{margin-top:16px;margin-bottom:8px;font-size:1rem}.import-section h2:first-child{margin-top:0}.import-row{gap:8px;display:flex}.import-input{border:1px solid var(--color-border);border-radius:var(--radius);flex:1;padding:8px 12px;font-size:.9rem}.import-input:focus{outline:2px solid var(--color-primary);border-color:#0000}.error-text{color:var(--color-danger);margin-top:6px;font-size:.85rem}.hint-text{color:var(--color-text-muted);margin-left:6px;font-size:.8rem;font-weight:400}.upload-buttons{flex-wrap:wrap;gap:8px;display:flex}.image-preview-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;margin-top:12px;display:grid}.image-preview{border-radius:var(--radius);aspect-ratio:1;position:relative;overflow:hidden}.image-preview img{object-fit:cover;width:100%;height:100%}.image-remove-btn{color:#fff;cursor:pointer;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:1rem;line-height:1;display:flex;position:absolute;top:4px;right:4px}.image-remove-btn:hover{background:var(--color-danger)}.ai-extract-section{align-items:center;gap:12px;margin-top:12px;display:flex}.body-textarea{font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:.85rem;line-height:1.5}hr{border:none;border-top:1px solid var(--color-border);margin:16px 0}.form-label{margin-bottom:14px;font-size:.9rem;font-weight:500;display:block}.form-label input,.form-label textarea{border:1px solid var(--color-border);border-radius:var(--radius);width:100%;margin-top:4px;padding:8px 12px;font-family:inherit;font-size:.9rem;display:block}.form-label input:focus,.form-label textarea:focus{outline:2px solid var(--color-primary);border-color:#0000}.tag-input-area{border:1px solid var(--color-border);border-radius:var(--radius);flex-wrap:wrap;align-items:center;gap:6px;min-height:40px;margin-top:4px;padding:6px;display:flex}.tag-text-input{border:none;outline:none;flex:1;min-width:120px;padding:4px;font-size:.85rem}.suggested-tags{flex-wrap:wrap;gap:4px;margin-top:6px;display:flex}.form-fieldset{border:1px solid var(--color-border);border-radius:var(--radius);margin-bottom:16px;padding:14px}.form-fieldset legend{padding:0 6px;font-size:.95rem;font-weight:600}.list-input-row{align-items:flex-start;gap:8px;margin-bottom:8px;display:flex}.list-input-row input,.list-input-row textarea{border:1px solid var(--color-border);border-radius:var(--radius);flex:1;padding:8px 12px;font-family:inherit;font-size:.9rem}.list-input-row input:focus,.list-input-row textarea:focus{outline:2px solid var(--color-primary);border-color:#0000}.step-number{color:var(--color-text-muted);min-width:24px;padding-top:8px;font-weight:600}.form-actions{gap:8px;margin-top:20px;display:flex}@media (width<=600px){.navbar{flex-wrap:wrap;gap:8px;padding:10px 12px}.user-name{display:none}.main-content{padding:16px 10px}.recipe-grid{grid-template-columns:1fr}.list-header{flex-direction:column;align-items:stretch;gap:8px}.import-row{flex-direction:column}}
