/* Magic Hotel — pannello admin */
@font-face{font-family:'Jost';src:url('../fonts/jost-400.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Jost';src:url('../fonts/jost-500.woff2') format('woff2');font-weight:500;font-display:swap}
@font-face{font-family:'Jost';src:url('../fonts/jost-600.woff2') format('woff2');font-weight:600;font-display:swap}
@font-face{font-family:'Jost';src:url('../fonts/jost-700.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'Cormorant';src:url('../fonts/cormorant-600.woff2') format('woff2');font-weight:600;font-display:swap}
:root{--ink:#2a2520;--soft:#5f574d;--mute:#8a8175;--line:#e6ddcd;--bg:#f3ede2;--paper:#fffdf9;--terra:#b4623c;--terra-d:#9a4f2d;--esp:#231e1a;--ok:#2e7d50;--r:8px}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Jost',-apple-system,sans-serif;background:var(--bg);color:var(--ink);font-size:15px;line-height:1.5}
a{color:var(--terra);text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
img{max-width:100%;display:block}
input,textarea,select{font-family:inherit;font-size:.95rem;width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r);background:var(--paper);color:var(--ink)}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--terra)}
label{display:block}
.hide{display:none!important}

/* login */
.login{position:fixed;inset:0;background:var(--esp);display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}
.login-card{background:var(--paper);border-radius:16px;padding:36px;width:min(94vw,380px);box-shadow:0 30px 80px -30px #000;text-align:center}
.login-card img{height:30px;margin:0 auto 18px}
.login-card h1{font-family:'Cormorant',serif;font-size:1.6rem;margin-bottom:4px}
.login-card p{color:var(--mute);font-size:.88rem;margin-bottom:20px}
.login-card input{margin-bottom:12px;text-align:center}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-weight:600;font-size:.9rem;padding:11px 20px;border-radius:var(--r);background:var(--terra);color:#fff;transition:background .2s,transform .2s}
.btn:hover{background:var(--terra-d);transform:translateY(-1px)}
.btn.sec{background:var(--paper);color:var(--ink);border:1px solid var(--line)}
.btn.sec:hover{background:var(--bg)}
.btn.sm{padding:7px 13px;font-size:.82rem}
.btn.danger{background:#fff;color:#b23b2c;border:1px solid #e7c3bd}
.btn.danger:hover{background:#fbeae7}
.login-err{color:#b23b2c;font-size:.85rem;min-height:1.2em}

/* layout */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.side{background:var(--esp);color:#efe9df;padding:20px 14px;position:sticky;top:0;height:100vh;overflow-y:auto;display:flex;flex-direction:column;gap:4px}
.side .brand{display:flex;align-items:center;gap:8px;padding:6px 10px 16px}
.side .brand img{height:24px;filter:none}
.side .brand b{font-family:'Cormorant',serif;font-size:1.2rem}
.navbtn{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:10px 12px;border-radius:var(--r);color:#c3bcae;font-weight:500;font-size:.9rem;transition:background .2s,color .2s}
.navbtn:hover{background:rgba(255,255,255,.06);color:#fff}
.navbtn.on{background:var(--terra);color:#fff}
.navbtn svg{width:17px;height:17px;flex:none}
.side .sp{flex:1}
.side .smallnote{font-size:.72rem;color:#8a8175;padding:10px}

/* main */
.main{display:flex;flex-direction:column;min-width:0}
.topbar{position:sticky;top:0;z-index:20;background:var(--paper);border-bottom:1px solid var(--line);padding:12px 24px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.topbar h2{font-family:'Cormorant',serif;font-size:1.5rem;flex:1;min-width:120px}
.badge{font-size:.72rem;font-weight:600;padding:4px 10px;border-radius:999px}
.badge.local{background:#fdeede;color:#b06a18}
.badge.sb{background:#e6f4ec;color:var(--ok)}
.saved{font-size:.8rem;color:var(--ok);opacity:0;transition:opacity .3s}
.saved.show{opacity:1}
.content{padding:24px;max-width:920px;width:100%}
.sec-intro{color:var(--soft);font-size:.9rem;margin-bottom:20px;background:var(--paper);border:1px solid var(--line);border-left:3px solid var(--terra);border-radius:var(--r);padding:12px 14px}
.card{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:20px;margin-bottom:18px}
.card h3{font-family:'Cormorant',serif;font-size:1.3rem;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.fld{margin-bottom:14px}
.fld>span{display:block;font-size:.74rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--mute);margin-bottom:5px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}

/* image field */
.imgf{display:flex;gap:12px;align-items:center}
.imgf .prev{width:84px;height:60px;border-radius:6px;object-fit:cover;background:var(--bg);border:1px solid var(--line);flex:none}
.imgf .ctrl{flex:1;display:flex;flex-direction:column;gap:6px}
.imgf input[type=file]{font-size:.8rem;padding:6px;border:1px dashed var(--line)}

/* list editor */
.item{border:1px solid var(--line);border-radius:10px;padding:14px;margin-bottom:10px;background:var(--bg);position:relative}
.item .ihead{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.item .ihead b{font-size:.8rem;color:var(--mute);text-transform:uppercase;letter-spacing:.06em}
.item .iact{display:flex;gap:6px}
.iact button{width:28px;height:28px;border-radius:6px;background:var(--paper);border:1px solid var(--line);display:grid;place-items:center;color:var(--soft)}
.iact button:hover{border-color:var(--terra);color:var(--terra)}
.iact .del:hover{border-color:#b23b2c;color:#b23b2c}
.addbtn{width:100%;border:1px dashed var(--line);border-radius:10px;padding:12px;color:var(--terra);font-weight:600;background:var(--paper)}
.addbtn:hover{background:var(--bg);border-color:var(--terra)}

/* bookings table */
.tbl{width:100%;border-collapse:collapse;font-size:.86rem}
.tbl th,.tbl td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--line)}
.tbl th{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--mute)}
.tbl tr:hover td{background:var(--bg)}
.empty{color:var(--mute);text-align:center;padding:30px}

@media(max-width:760px){
 .app{grid-template-columns:1fr}
 .side{position:static;height:auto;flex-direction:row;flex-wrap:wrap;gap:6px}
 .side .brand{width:100%}.side .sp,.side .smallnote{display:none}
 .navbtn{width:auto}
 .row2,.row3{grid-template-columns:1fr}
}
