.layout-header{border-bottom:1px solid var(--border);background:var(--paper);justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.5rem;display:flex}.layout-brand{font-family:var(--handwriting);color:var(--text-h);font-size:1.75rem;text-decoration:none}.layout-nav{gap:1.25rem;display:flex}.layout-nav a{color:var(--text);font-size:.95rem;text-decoration:none}.layout-nav a:hover{color:var(--accent)}.layout-main{text-align:left;background:linear-gradient(180deg, var(--paper) 0%, var(--paper-dark) 100%);min-height:60vh;padding:1.5rem}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:1.5rem;display:flex}.page-header-actions{gap:.75rem;display:flex}.restaurant-index{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.5rem;margin:0;padding:0;list-style:none;display:grid}.restaurant-tab{--tab-rotate:0deg;background:var(--paper);border:1px solid var(--border);min-height:7rem;box-shadow:var(--shadow-card);transform:rotate(var(--tab-rotate));color:inherit;border-radius:3px;padding:1.25rem 1rem;text-decoration:none;transition:transform .2s,box-shadow .2s;display:block;position:relative}.restaurant-tab:before{content:"";border:1px solid var(--border);background:#d4c8b899;width:3rem;height:1rem;position:absolute;top:-6px;left:50%;transform:translate(-50%)}.restaurant-tab:hover{box-shadow:var(--shadow-lift);z-index:1;transform:rotate(0)translateY(-4px)}.restaurant-tab--add{background:var(--paper-dark);font-family:var(--handwriting);color:var(--accent);border-style:dashed;justify-content:center;align-items:center;font-size:1.25rem;display:flex}.restaurant-tab-name{font-family:var(--heading);color:var(--text-h);margin-top:.5rem;font-size:1.2rem;font-weight:600;display:block}.restaurant-tab-location{color:var(--text-muted);margin-top:.35rem;font-size:.9rem;display:block}.restaurant-tab-meta{color:var(--text-muted);margin-top:.65rem;font-size:.8rem;display:block}.restaurant-page-header{margin-bottom:1.5rem}.restaurant-location{color:var(--text-muted);margin:0;font-size:1rem}.dish-collage{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.75rem;margin:0;padding:0;list-style:none;display:grid}.page-form{max-width:28rem}.page-form form{background:var(--paper);border:1px solid var(--border);box-shadow:var(--shadow-card);flex-direction:column;gap:1rem;margin-top:1.5rem;padding:1.25rem;display:flex;transform:rotate(-.5deg)}.page-form label{color:var(--text-h);flex-direction:column;gap:.35rem;font-size:.95rem;display:flex}.label-optional{color:var(--text-muted);font-weight:400}.page-form input{border:1px solid var(--border);font:inherit;color:var(--text-h);background:var(--bg);border-radius:4px;padding:.5rem .75rem}.page-form .btn{align-self:flex-start}.add-dish-overlay{z-index:100;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.add-dish-backdrop{cursor:pointer;background:#2a221873;border:none;position:absolute;inset:0}.add-dish-panel{background:var(--paper);border:1px solid var(--border);width:min(100%,26rem);max-height:90vh;box-shadow:var(--shadow-lift);border-radius:6px;padding:1.5rem;position:relative;overflow-y:auto}.add-dish-title{font-family:var(--handwriting);color:var(--text-h);margin:0 0 1rem;font-size:1.75rem}.add-dish-form{flex-direction:column;gap:.85rem;display:flex}.add-dish-form label{color:var(--text-h);flex-direction:column;gap:.35rem;font-size:.9rem;display:flex}.add-dish-form input,.add-dish-form textarea{border:1px solid var(--border);font:inherit;color:var(--text-h);background:var(--bg);border-radius:4px;padding:.5rem .75rem}.add-dish-preview{object-fit:cover;border:1px solid var(--border);border-radius:4px;width:100%;max-height:10rem}.add-dish-actions{justify-content:flex-end;gap:.75rem;margin-top:.5rem;display:flex}.form-error{color:#b42318;margin:0;font-size:.9rem}.star-rating{align-items:center;gap:.15rem;display:flex}.star{color:var(--border);font-size:1rem;line-height:1}.star--on{color:var(--accent)}.star-rating-value{color:var(--text-h);margin-left:.35rem;font-size:.85rem;font-weight:600}.dish-card{--rotate:0deg;background:var(--paper);border:1px solid var(--border);box-shadow:var(--shadow-card);transform:rotate(var(--rotate));border-radius:4px;flex-direction:column;transition:transform .2s,box-shadow .2s;display:flex;overflow:hidden}.dish-card:hover{box-shadow:var(--shadow-lift);z-index:1;transform:rotate(0)scale(1.02)}.dish-card-photo-wrap{aspect-ratio:4/3;background:var(--paper-dark);overflow:hidden}.dish-card-photo{object-fit:cover;width:100%;height:100%;display:block}.dish-card-photo-placeholder{width:100%;height:100%;color:var(--text-muted);background:repeating-linear-gradient(-45deg, var(--paper-dark), var(--paper-dark) 8px, var(--paper) 8px, var(--paper) 16px);justify-content:center;align-items:center;font-size:.85rem;display:flex}.dish-card-body{padding:.85rem 1rem 1rem}.dish-card-name{font-family:var(--heading);color:var(--text-h);margin:0 0 .4rem;font-size:1.15rem;font-weight:600}.dish-card-comment{color:var(--text);margin:.5rem 0 0;font-size:.9rem;line-height:1.45}:root{--text:#5c5348;--text-h:#2a2218;--text-muted:#8a7f72;--bg:#ebe4d6;--paper:#f7f2e9;--paper-dark:#e8dfd0;--border:#d4c8b8;--accent:#b85c38;--accent-bg:#b85c3824;--accent-border:#b85c3880;--shadow-card:2px 3px 12px #2a22181a;--shadow-lift:4px 8px 24px #2a221829;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:Georgia, "Times New Roman", serif;--handwriting:"Segoe Print", "Bradley Hand", "Comic Sans MS", cursive;font:18px/1.5 var(--sans);color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{box-sizing:border-box;background:var(--paper);border-inline:1px solid var(--border);width:960px;max-width:100%;min-height:100svh;margin:0 auto;box-shadow:0 0 40px #2a22180f}body{background:var(--bg);color:var(--text);margin:0}h1{font-family:var(--handwriting);color:var(--text-h);margin:0 0 .5rem;font-size:2.25rem;font-weight:400}h2{font-family:var(--heading);color:var(--text-h);font-weight:600}p{margin:0}a{color:var(--accent)}.btn{font:inherit;cursor:pointer;border:1px solid #0000;border-radius:4px;padding:.5rem 1rem;text-decoration:none;display:inline-block}.btn--primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn--primary:hover{filter:brightness(1.05)}.btn--primary:disabled{opacity:.6;cursor:not-allowed}.btn--ghost{color:var(--text-h);border-color:var(--border);background:0 0}.btn--ghost:hover{background:var(--paper-dark)}.page-message{color:var(--text-muted);font-style:italic}.page-error{color:#b42318}.page-empty{text-align:center;background:var(--paper-dark);border:1px dashed var(--border);border-radius:4px;margin-top:1.5rem;padding:2rem}.page-empty p{margin-bottom:.75rem}.page-back{margin:0 0 1rem}.page-back a{color:var(--text-muted);font-size:.95rem;text-decoration:none}.page-back a:hover{color:var(--accent)}
