*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Jost',sans-serif;font-weight:300;font-size:16px;line-height:1.7;color:#1C1A17;background:#F9F6EF}
a{color:inherit;text-decoration:none}
img{display:block;width:100%}
input,select,textarea,button{font-family:inherit}
:root{--calce:#F9F6EF;--calce-dark:#EDE9DD;--pietra:#7A7168;--pietra-dark:#4A4540;--verde:#3D5A42;--verde-light:#6A8C6F;--terra:#A0522D;--terra-light:#C97B50;--nero:#1C1A17;--bianco:#FFFFFF;--rosso:#C0392B;--nav-h:72px;--radius:2px;--radius-lg:6px;--transition:.3s ease;--font-display:'Cormorant Garamond',Georgia,serif;--font-body:'Jost',sans-serif}
.display{font-family:var(--font-display);font-weight:300;line-height:1.15;letter-spacing:-.01em}
.display-xl{font-size:clamp(2.8rem,6vw,5rem)}
.display-lg{font-size:clamp(2rem,4vw,3.2rem)}
.display-md{font-size:clamp(1.5rem,2.5vw,2rem)}
.label{font-size:.7rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--pietra)}
.container{max-width:1280px;margin:0 auto;padding:0 5vw}
.container--narrow{max-width:680px;margin:0 auto;padding:0 5vw}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}
#navbar{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 5vw;transition:background var(--transition),box-shadow var(--transition)}
#navbar.scrolled,body:not(.page-hero) #navbar{background:rgba(249,246,239,.97);backdrop-filter:blur(8px);box-shadow:0 1px 0 rgba(74,69,64,.12)}
.nav-logo{font-family:var(--font-display);font-size:1.5rem;font-weight:400;letter-spacing:.02em;color:var(--bianco);transition:color var(--transition)}
body:not(.page-hero) .nav-logo,#navbar.scrolled .nav-logo{color:var(--nero)}
.nav-links{display:flex;gap:2rem;list-style:none;align-items:center}
.nav-links a{font-size:.75rem;font-weight:400;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.85);transition:color var(--transition);position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1px;background:currentColor;transition:width var(--transition)}
.nav-links a:hover::after{width:100%}
body:not(.page-hero) .nav-links a,#navbar.scrolled .nav-links a{color:var(--pietra-dark)}
.nav-cta{font-size:.72rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;padding:9px 20px;border:1px solid rgba(255,255,255,.5);border-radius:var(--radius);color:var(--bianco)!important;transition:background var(--transition)!important}
.nav-cta:hover{background:rgba(255,255,255,.15)!important}
body:not(.page-hero) .nav-cta,#navbar.scrolled .nav-cta{border-color:var(--verde)!important;color:var(--verde)!important;background:transparent!important}
body:not(.page-hero) .nav-cta:hover,#navbar.scrolled .nav-cta:hover{background:var(--verde)!important;color:var(--bianco)!important}
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.nav-hamburger span{display:block;width:24px;height:1.5px;background:var(--bianco);transition:background var(--transition)}
body:not(.page-hero) .nav-hamburger span{background:var(--nero)}
@media(max-width:900px){.nav-links{display:none}.nav-hamburger{display:flex}}
.flash-container{position:fixed;top:calc(var(--nav-h) + 12px);left:50%;transform:translateX(-50%);z-index:200;display:flex;flex-direction:column;gap:8px;min-width:320px;max-width:600px}
.flash{display:flex;justify-content:space-between;align-items:center;padding:12px 18px;border-radius:var(--radius-lg);font-size:.88rem;gap:12px}
.flash--success{background:#e8f5e9;color:#2e7d32;border:1px solid #c8e6c9}
.flash--error{background:#fdecea;color:#c62828;border:1px solid #ffcdd2}
.flash-close{background:none;border:none;cursor:pointer;font-size:1rem;opacity:.6}
.alert{padding:14px 18px;border-radius:var(--radius);margin-bottom:24px;font-size:.9rem}
.alert--error{background:#fdecea;color:#c62828;border-left:3px solid var(--rosso)}
.alert--success{background:#e8f5e9;color:#2e7d32;border-left:3px solid var(--verde)}
.alert ul{padding-left:18px}
.btn-primary{display:inline-block;padding:14px 28px;background:var(--verde);color:var(--bianco);border:none;border-radius:var(--radius);font-size:.78rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;transition:background var(--transition);text-align:center}
.btn-primary:hover{background:var(--pietra-dark)}
.btn-primary.btn-full{width:100%}
.btn-primary.btn-lg{padding:18px 32px;font-size:.82rem}
.btn-outline{display:inline-block;padding:10px 20px;border:1px solid var(--verde);border-radius:var(--radius);color:var(--verde);font-size:.72rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:background var(--transition),color var(--transition)}
.btn-outline:hover{background:var(--verde);color:var(--bianco)}
.btn-outline.btn-sm{padding:7px 14px;font-size:.68rem}
.btn-danger-sm{padding:5px 10px;background:none;border:1px solid #e57373;border-radius:var(--radius);color:#c62828;font-size:.7rem;cursor:pointer;transition:background var(--transition)}
.btn-danger-sm:hover{background:#fdecea}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-size:.68rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--pietra)}
.form-group input,.form-group select,.form-group textarea{background:var(--bianco);border:1px solid var(--calce-dark);border-radius:var(--radius);padding:11px 14px;font-size:.92rem;color:var(--nero);outline:none;transition:border-color var(--transition);width:100%}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--verde)}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--pietra)}
.form-group textarea{resize:vertical;min-height:100px}
.checkbox-label{display:flex;align-items:flex-start;gap:10px;font-size:.88rem;color:var(--pietra-dark);cursor:pointer;text-transform:none;letter-spacing:0;font-weight:300}
.checkbox-label input[type=checkbox]{width:auto;margin-top:3px;flex-shrink:0}
.checkbox-label a{color:var(--verde);text-decoration:underline}
section{padding:100px 0}
.section-header{margin-bottom:60px}
.divider{width:40px;height:1px;background:var(--terra-light);margin:20px 0}
.case-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:32px}
.casa-card{border-radius:var(--radius-lg);overflow:hidden;background:var(--bianco);transition:transform var(--transition),box-shadow var(--transition)}
.casa-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(61,90,66,.12)}
.casa-card--occupata{opacity:.65;pointer-events:none}
.casa-img{position:relative;aspect-ratio:4/3;overflow:hidden}
.casa-img img{height:100%;object-fit:cover;transition:transform .5s ease}
.casa-card:hover .casa-img img{transform:scale(1.04)}
.casa-badge{position:absolute;top:16px;right:16px;background:var(--bianco);color:var(--verde);font-size:.65rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;padding:4px 12px;border-radius:20px}
.casa-badge--occupata{background:#fdecea;color:#c62828}
.casa-badge--warn{background:#fff8e1;color:#e65100}
.casa-body{padding:24px}
.casa-body h3{font-family:var(--font-display);font-size:1.5rem;font-weight:400;margin-bottom:6px}
.casa-meta{display:flex;gap:16px;margin:12px 0;font-size:.78rem;color:var(--pietra);flex-wrap:wrap}
.casa-desc{font-size:.88rem;color:var(--pietra-dark);margin-bottom:20px;line-height:1.6}
.casa-footer{display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:1px solid var(--calce-dark);gap:12px}
.casa-price .da{font-size:.7rem;color:var(--pietra)}
.casa-price .prezzo{font-family:var(--font-display);font-size:1.6rem;font-weight:300;color:var(--verde)}
.casa-price .notte{font-size:.7rem;color:var(--pietra)}
.tag-occupata{font-size:.75rem;color:#c62828}
.tag-warn{font-size:.75rem;color:#e65100}
.booking-bar-inner{background:var(--bianco);border-radius:var(--radius-lg);padding:24px 28px;display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:0;box-shadow:0 8px 40px rgba(0,0,0,.12)}
.bb-field{padding:0 20px;border-right:1px solid var(--calce-dark)}
.bb-field:first-child{padding-left:0}
.bb-field:last-child{border-right:none;padding-right:0}
.bb-label{font-size:.65rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--pietra);margin-bottom:6px}
.bb-field input[type=date],.bb-field input[type=number]{border:none;outline:none;font-size:.95rem;color:var(--nero);background:transparent;width:100%;padding:0}
.bb-submit{padding:0 28px;background:var(--verde);color:var(--bianco);border:none;border-radius:var(--radius);font-size:.75rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:background var(--transition);white-space:nowrap;margin-left:20px}
.bb-submit:hover{background:var(--pietra-dark)}
@media(max-width:768px){.booking-bar-inner{grid-template-columns:1fr 1fr;gap:16px}.bb-field{border-right:none;padding:0;border-bottom:1px solid var(--calce-dark);padding-bottom:12px}.bb-submit{grid-column:1/-1;padding:14px;margin-left:0}}
.page-cerca main,.page-conferma main,.page-grazie main,.page-area main{padding-top:calc(var(--nav-h) + 60px);padding-bottom:80px}
.cerca-header{margin-bottom:32px}
.cerca-riepilogo{color:var(--pietra);margin-top:8px;font-size:.9rem}
.cerca-form{margin-bottom:40px}
.page-auth main{padding-top:var(--nav-h)}
.auth-main{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:80px 20px}
.auth-box{background:var(--bianco);border-radius:var(--radius-lg);padding:48px;width:100%;max-width:440px;box-shadow:0 4px 32px rgba(0,0,0,.08);display:flex;flex-direction:column;gap:24px}
.auth-box--wide{max-width:580px}
.auth-logo{font-family:var(--font-display);font-size:1.2rem;font-weight:400;text-align:center;color:var(--verde)}
.auth-box h1{font-family:var(--font-display);font-size:1.8rem;font-weight:400;text-align:center}
.auth-box form{display:flex;flex-direction:column;gap:18px}
.auth-links{text-align:center;font-size:.82rem;color:var(--pietra)}
.auth-links a{color:var(--verde);text-decoration:underline}
.conferma-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:60px;align-items:start}
@media(max-width:900px){.conferma-layout{grid-template-columns:1fr}}
.riepilogo-box{position:sticky;top:calc(var(--nav-h) + 24px);background:var(--bianco);border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 4px 24px rgba(0,0,0,.08)}
.riepilogo-img img{aspect-ratio:16/9;object-fit:cover}
.riepilogo-body{padding:24px}
.riepilogo-body h3{font-family:var(--font-display);font-size:1.4rem;font-weight:400;margin-bottom:20px}
.riepilogo-dates{display:flex;align-items:center;gap:16px;margin-bottom:20px}
.riepilogo-lbl{font-size:.65rem;text-transform:uppercase;letter-spacing:.15em;color:var(--pietra)}
.riepilogo-val{font-size:1rem;font-weight:400}
.riepilogo-table{width:100%;font-size:.85rem;border-collapse:collapse}
.riepilogo-table td{padding:7px 0;border-bottom:1px solid var(--calce-dark)}
.riepilogo-table td:last-child{text-align:right;font-weight:400}
.riepilogo-note{font-size:.78rem;color:var(--pietra);margin-top:16px;line-height:1.5}
.conferma-form-wrap h2{font-family:var(--font-display);font-size:1.6rem;font-weight:400;margin-bottom:28px}
.form-prenotazione{display:flex;flex-direction:column;gap:18px}
.form-note{font-size:.78rem;color:var(--pietra);line-height:1.5}
.grazie-box{background:var(--bianco);border-radius:var(--radius-lg);padding:56px 48px;text-align:center;box-shadow:0 4px 32px rgba(0,0,0,.07)}
.grazie-icon{width:64px;height:64px;border-radius:50%;background:#e8f5e9;color:var(--verde);display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin:0 auto 24px}
.grazie-sub{color:var(--pietra-dark);margin:16px 0 32px;font-size:.95rem;line-height:1.7}
.grazie-riepilogo{text-align:left;border:1px solid var(--calce-dark);border-radius:var(--radius);padding:24px;margin-bottom:24px}
.gr-row{display:flex;justify-content:space-between;padding:8px 0;font-size:.88rem;border-bottom:1px solid var(--calce-dark)}
.gr-row:last-child{border-bottom:none}
.gr-row--total{font-weight:500;font-size:1rem}
.grazie-note{font-size:.82rem;color:var(--pietra);margin-bottom:28px}
.grazie-actions{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
.area-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:48px;gap:16px;flex-wrap:wrap}
.area-empty{text-align:center;padding:60px 0;color:var(--pietra);display:flex;flex-direction:column;align-items:center;gap:20px}
.prenotazioni-lista{display:flex;flex-direction:column;gap:20px}
.pren-card{background:var(--bianco);border-radius:var(--radius-lg);overflow:hidden;display:grid;grid-template-columns:200px 1fr;box-shadow:0 2px 12px rgba(0,0,0,.06)}
@media(max-width:700px){.pren-card{grid-template-columns:1fr}}
.pren-img img{width:200px;height:100%;object-fit:cover}
@media(max-width:700px){.pren-img img{width:100%;height:180px}}
.pren-body{padding:24px;display:flex;flex-direction:column;gap:16px}
.pren-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.pren-top h3{font-family:var(--font-display);font-size:1.3rem;font-weight:400}
.pren-dates{display:flex;gap:28px;flex-wrap:wrap;font-size:.88rem}
.pren-lbl{font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;color:var(--pietra);margin-bottom:2px}
.pren-footer{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid var(--calce-dark);flex-wrap:wrap;gap:12px}
.pren-prezzo{font-family:var(--font-display);font-size:1.4rem;font-weight:300;color:var(--verde)}
.stato-badge{padding:4px 12px;border-radius:20px;font-size:.68rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;white-space:nowrap}
.stato--attesa{background:#fff8e1;color:#e65100}
.stato--ok{background:#e8f5e9;color:#2e7d32}
.stato--no{background:#fdecea;color:#c62828}
.stato--grigio{background:var(--calce-dark);color:var(--pietra)}
.admin-body #navbar{background:rgba(249,246,239,.97);box-shadow:0 1px 0 rgba(74,69,64,.12)}
.admin-body .nav-logo{color:var(--nero)}
.admin-body .nav-links a{color:var(--pietra-dark)}
.admin-main{padding-top:calc(var(--nav-h) + 32px);padding-bottom:80px}
.admin-container{max-width:1400px;margin:0 auto;padding:0 5vw}
.admin-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;gap:20px;flex-wrap:wrap}
.admin-topbar h1{font-family:var(--font-display);font-size:2rem;font-weight:300}
.admin-nav-links{display:flex;gap:0;border-bottom:1px solid var(--calce-dark);margin-bottom:8px}
.admin-nav-links a{padding:10px 20px;font-size:.78rem;font-weight:400;letter-spacing:.1em;text-transform:uppercase;color:var(--pietra);border-bottom:2px solid transparent;transition:color var(--transition)}
.admin-nav-links a:hover,.admin-nav-links a.active{color:var(--verde);border-bottom-color:var(--verde)}
.admin-kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:40px}
.kpi-card{background:var(--bianco);border-radius:var(--radius-lg);padding:24px;box-shadow:0 2px 8px rgba(0,0,0,.05)}
.kpi-card--warn{border-left:3px solid #e65100}
.kpi-card--green{border-left:3px solid var(--verde)}
.kpi-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.16em;color:var(--pietra);margin-bottom:8px}
.kpi-value{font-family:var(--font-display);font-size:2.2rem;font-weight:300}
.admin-cols{display:grid;grid-template-columns:1.6fr 1fr;gap:32px;align-items:start}
@media(max-width:1000px){.admin-cols{grid-template-columns:1fr}}
.admin-section{background:var(--bianco);border-radius:var(--radius-lg);padding:28px;box-shadow:0 2px 8px rgba(0,0,0,.05)}
.admin-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.admin-section h2{font-family:var(--font-display);font-size:1.3rem;font-weight:400;margin-bottom:20px}
.link-all,.link-edit{font-size:.78rem;color:var(--verde)}
.admin-empty{color:var(--pietra);font-size:.88rem;padding:20px 0}
.admin-table-wrap{overflow-x:auto}
.admin-table{width:100%;border-collapse:collapse;font-size:.85rem}
.admin-table th{text-align:left;padding:10px 12px;font-size:.65rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--pietra);border-bottom:1px solid var(--calce-dark)}
.admin-table td{padding:12px;border-bottom:1px solid var(--calce-dark);vertical-align:middle}
.admin-table tr:last-child td{border-bottom:none}
.admin-table tr:hover td{background:var(--calce)}
.admin-table code{font-family:monospace;font-size:.82rem;background:var(--calce-dark);padding:2px 6px;border-radius:2px}
.admin-card{background:var(--bianco);border-radius:var(--radius-lg);padding:28px;box-shadow:0 2px 8px rgba(0,0,0,.05);margin-bottom:24px}
.admin-card h3{font-family:var(--font-display);font-size:1.2rem;font-weight:400;margin-bottom:20px}
.admin-form-inline{display:flex;gap:16px;align-items:flex-end;flex-wrap:wrap}
.admin-form-inline .form-group{flex:1;min-width:140px}
.admin-form-inline .btn-primary{flex-shrink:0;padding:11px 24px;height:fit-content}
.pren-admin-layout{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
@media(max-width:900px){.pren-admin-layout{grid-template-columns:1fr}}
.detail-table{width:100%;font-size:.88rem;border-collapse:collapse}
.detail-table td{padding:9px 0;border-bottom:1px solid var(--calce-dark)}
.detail-table td:first-child{color:var(--pietra);width:40%}
.detail-table tr:last-child td{border-bottom:none}
.arrivi-lista{list-style:none;display:flex;flex-direction:column;gap:12px}
.arrivo-item{display:flex;align-items:center;gap:16px;padding:12px 0;border-bottom:1px solid var(--calce-dark)}
.arrivo-item:last-child{border-bottom:none}
.arrivo-data{font-family:var(--font-display);font-size:1.2rem;font-weight:400;color:var(--verde);min-width:44px}
.arrivo-nome{font-size:.9rem;font-weight:400}
.arrivo-casa{font-size:.78rem;color:var(--pietra)}
.arrivo-item .link-edit{margin-left:auto;font-size:1rem}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:60px}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.footer-grid{grid-template-columns:1fr}.case-grid{grid-template-columns:1fr}}
#footer{background:#1C1A17;color:rgba(255,255,255,.55);padding:60px 0 32px}
.footer-brand .f-logo{font-family:var(--font-display);font-size:1.6rem;font-weight:300;color:#fff;margin-bottom:12px}
.footer-brand p{font-size:.82rem;line-height:1.7}
.footer-col h5{font-size:.68rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:16px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col ul a{font-size:.85rem;color:rgba(255,255,255,.5);transition:color var(--transition)}
.footer-col ul a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:28px;display:flex;justify-content:space-between;align-items:center;font-size:.75rem}

/* ---- Carosello ------------------------------------------ */
.carosello-wrap{position:relative;overflow:hidden;background:var(--nero)}
.carosello-track{display:flex;transition:transform 0.6s cubic-bezier(.4,0,.2,1)}
.carosello-slide{min-width:100%;position:relative}
.carosello-slide img{width:100%;height:70vh;object-fit:cover;opacity:.85}
.carosello-caption{position:absolute;bottom:48px;left:5vw;color:var(--bianco)}
.carosello-caption h3{font-family:var(--font-display);font-size:clamp(1.5rem,3vw,2.5rem);font-weight:300;font-style:italic}
.carosello-caption p{font-size:.8rem;letter-spacing:.15em;text-transform:uppercase;opacity:.6;margin-top:6px}
.carosello-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);color:var(--bianco);width:48px;height:48px;border-radius:50%;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:background .3s ease;backdrop-filter:blur(4px)}
.carosello-nav:hover{background:rgba(255,255,255,.3)}
.carosello-prev{left:24px}
.carosello-next{right:24px}
.carosello-dots{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);display:flex;gap:8px}
.carosello-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.4);cursor:pointer;transition:background .3s ease}
.carosello-dot.active{background:var(--bianco);width:24px;border-radius:3px}
