:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:#0f172a;background-color:#f8fafc}body{margin:0;padding:0;background-color:#f8fafc}#root{min-height:100vh}.app-shell{max-width:1200px;margin:0 auto;padding:2rem 1.5rem 4rem}h1{font-size:2.25rem;margin-bottom:1.5rem}.filters{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.filters select,.filters input{font-size:1rem;padding:.5rem .75rem;border-radius:.5rem;border:1px solid #cbd5f5}.layout{display:grid;grid-template-columns:320px 1fr;gap:1.5rem}@media (max-width: 960px){.layout{grid-template-columns:1fr}}.list-card,.detail-card,.form-card{background:#fff;border-radius:1rem;border:1px solid #e2e8f0;padding:1rem;box-shadow:0 10px 25px -20px #0f172a80}.recette-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid #f1f5f9;cursor:pointer}.recette-item:last-child{border-bottom:none}.recette-item__title{font-weight:600}.recette-item__category{font-size:.85rem;color:#475569}.star-button{background:none;border:none;cursor:pointer;font-size:1.5rem;color:#cbd5f5}.star-button.active{color:#facc15}.detail-card h2{margin:0;font-size:1.5rem}.detail-card pre{white-space:pre-wrap;font-size:1rem;line-height:1.6;background:#f8fafc;padding:1rem;border-radius:.5rem}button.primary,button.secondary,button.danger{border:none;border-radius:.5rem;padding:.65rem 1rem;cursor:pointer;font-size:.95rem;transition:filter .15s ease}button.primary{background-color:#2563eb;color:#fff}button.secondary{background-color:#e2e8f0;color:#0f172a}button.danger{background-color:#dc2626;color:#fff}button:disabled{opacity:.6;cursor:not-allowed}button:hover:not(:disabled){filter:brightness(1.05)}.form-card form{display:flex;flex-direction:column;gap:.75rem}.form-card label{font-weight:600}.form-card input,.form-card select,.form-card textarea{width:calc(100% - 2px);padding:.75rem;font-size:1rem;border-radius:.5rem;border:1px solid #cbd5f5;box-sizing:border-box}.form-card textarea{min-height:160px}.bullet-list{padding-left:1.25rem;margin:.5rem 0 0;line-height:1.6}.muted{color:#94a3b8}.badge{display:inline-flex;align-items:center;gap:.35rem;background-color:#f1f5f9;padding:.25rem .5rem;border-radius:999px;font-size:.85rem;font-weight:600;color:#475569}.empty-state{color:#94a3b8;text-align:center;padding:2rem 0}.error-banner{background:#fee2e2;color:#991b1b;border:1px solid #fecaca;padding:.75rem 1rem;border-radius:.75rem;margin-bottom:1rem}.loading{color:#475569}
