:root{
  --bg:#0e1117;--bg2:#161b24;--bg3:#1e2535;--card:#1a2030;--line:rgba(255,255,255,.1);
  --red:#e63946;--red2:#ff4d5a;--text:#fff;--off:#c8d0dc;--muted:#7a8599;--ok:#42d77d;
  --radius:12px;--shadow:0 20px 70px rgba(0,0,0,.32)
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;background:var(--bg);color:var(--text)}
a{color:inherit}
button,input,select,textarea{font:inherit}
nav{position:sticky;top:0;z-index:20;background:rgba(14,17,23,.92);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav-inner{max-width:1180px;margin:auto;padding:.85rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand{display:flex;align-items:center;gap:.65rem;text-decoration:none;font-weight:900}
.logo{width:86px;height:46px;border-radius:8px;background:#fff;display:grid;place-items:center;color:var(--red);font-size:.62rem;font-weight:900;text-align:center;line-height:1.05;overflow:hidden;padding:3px}
.logo img{width:100%;height:100%;object-fit:contain}
.nav-links{display:flex;gap:1.2rem;align-items:center}
.nav-links a{font-size:.82rem;color:var(--off);text-decoration:none}
.nav-links a:hover{color:#fff}
.btn{border:0;border-radius:8px;padding:.72rem 1rem;background:var(--red);color:#fff;font-weight:800;text-decoration:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:.45rem}
.btn:hover{background:var(--red2)}
.btn.dark{background:#111;color:#fff;border:1px solid var(--line)}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--off)}
.btn.ok{background:var(--ok);color:#07120b}
.container{max-width:1180px;margin:auto;padding:0 1.25rem}
section{padding:4.8rem 0}
.hero{min-height:88vh;display:grid;place-items:center;position:relative;overflow:hidden;background:linear-gradient(180deg,rgba(14,17,23,.35),var(--bg)),var(--hero,linear-gradient(135deg,#111827,#1f2937));background-size:cover;background-position:center}
.hero::before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.28)}
.hero .container{position:relative;text-align:center}
.chip{display:inline-flex;padding:.25rem .6rem;border-radius:100px;background:rgba(230,57,70,.16);border:1px solid rgba(230,57,70,.35);color:#fff;font-size:.7rem;font-weight:800;margin-bottom:1rem}
h1{font-size:clamp(2.5rem,7vw,5.4rem);line-height:.98;margin:.2rem 0 1rem;letter-spacing:0;font-weight:950}
h1 span,.red{color:var(--red2)}
.lead{max-width:680px;margin:0 auto 1.4rem;color:var(--off);line-height:1.7}
.hero-actions{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap}
.stats{margin-top:2.6rem;display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:1.5rem}
.stat strong{display:block;font-size:1.7rem}.stat span{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.section-head{display:flex;align-items:end;justify-content:space-between;gap:1rem;margin-bottom:1.6rem;flex-wrap:wrap}
.kicker{font-size:.7rem;color:var(--red2);font-weight:900;letter-spacing:.16em;text-transform:uppercase}
h2{font-size:clamp(1.8rem,4vw,3rem);line-height:1.08;margin:.35rem 0 .4rem}
.sub{max-width:560px;color:var(--muted);line-height:1.7;font-size:.93rem}
.tabs{display:flex;gap:.45rem;flex-wrap:wrap}
.tab{background:var(--bg3);color:var(--off);border:1px solid var(--line);border-radius:100px;padding:.48rem .85rem;cursor:pointer;font-size:.78rem;font-weight:700}
.tab.active,.tab:hover{background:var(--red);border-color:var(--red);color:#fff}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:0 8px 30px rgba(0,0,0,.18)}
.product{cursor:pointer;transition:.2s}
.product:hover{transform:translateY(-4px);border-color:rgba(230,57,70,.45)}
.photo{aspect-ratio:16/10;background:var(--bg3);position:relative;overflow:hidden}
.photo img{width:100%;height:100%;object-fit:cover;display:block}
.badge{position:absolute;top:.75rem;left:.75rem;background:rgba(14,17,23,.84);border:1px solid var(--line);border-radius:100px;padding:.28rem .62rem;font-size:.68rem;font-weight:850}
.card-body{padding:1.05rem}
.meta{color:var(--red2);font-size:.68rem;font-weight:900;letter-spacing:.11em;text-transform:uppercase;margin-bottom:.35rem}
.product h3,.package h3,.blog-card h3{margin:.1rem 0 .45rem;font-size:1.08rem}
.desc{color:var(--muted);font-size:.82rem;line-height:1.6}
.price{font-size:1.35rem;font-weight:950;margin-top:.8rem}
.small{color:var(--muted);font-size:.74rem}
.chips{display:flex;gap:.35rem;flex-wrap:wrap;margin-top:.85rem}
.mini-chip{border:1px solid var(--line);background:rgba(255,255,255,.04);border-radius:100px;padding:.22rem .52rem;font-size:.68rem;color:var(--off)}
.quick-specs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.35rem;margin:.75rem 0 .25rem}
.quick-specs div{border:1px solid rgba(230,57,70,.22);background:rgba(230,57,70,.08);border-radius:8px;padding:.46rem .5rem;min-width:0}
.quick-specs span{display:block;color:#ff9aa3;font-size:.56rem;font-weight:950;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.14rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.quick-specs strong{display:block;color:#fff;font-size:.7rem;line-height:1.28;overflow-wrap:anywhere}
.spec-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem;margin:.75rem 0 .25rem}
.spec-grid div{border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.045);border-radius:8px;padding:.55rem .65rem}
.spec-grid span{display:block;color:var(--muted);font-size:.62rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.2rem}
.spec-grid strong{display:block;color:#f4f7fb;font-size:.78rem;line-height:1.35}
.spec-grid.compact{grid-template-columns:1fr;gap:.35rem;margin:.65rem 0 .1rem}
.spec-grid.compact div{padding:.45rem .55rem}
.spec-grid.compact strong{font-size:.72rem}
.band{background:var(--bg2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.package{padding:1.2rem}
.package.featured{border-color:rgba(230,57,70,.65)}
.product-family-links{margin:-.45rem 0 1rem}
.detail-page{padding:4.2rem 0 3.2rem}
.detail-page .container{max-width:1120px}
.detail-page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1.5rem;margin-bottom:2rem;padding-bottom:1.2rem;border-bottom:1px solid rgba(255,255,255,.1)}
.detail-page-head h1{font-size:clamp(2.35rem,5vw,4.4rem);line-height:1;margin:.25rem 0 .8rem}
.detail-page-head .lead{margin:0;max-width:760px;text-align:left;font-size:1rem}
.model-detail-list{display:grid;gap:1.25rem}
.model-detail{display:grid;grid-template-columns:minmax(320px,.82fr) 1fr;gap:0;overflow:hidden;border-radius:14px}
.model-gallery{display:grid;grid-template-rows:1fr auto;gap:.55rem;background:#0f141d;padding:.75rem;border-right:1px solid var(--line)}
.model-main-photo{position:relative;aspect-ratio:4/3;border-radius:10px;overflow:hidden;background:var(--bg3)}
.model-main-photo img{width:100%;height:100%;object-fit:cover;display:block}
.model-gallery-btn{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border:1px solid rgba(255,255,255,.28);border-radius:999px;background:rgba(14,17,23,.72);color:#fff;font-size:1.65rem;line-height:1;display:grid;place-items:center;cursor:pointer;backdrop-filter:blur(8px)}
.model-gallery-btn:hover{background:var(--red);border-color:var(--red)}
.model-gallery-btn.prev{left:.55rem}
.model-gallery-btn.next{right:.55rem}
.model-gallery-count{position:absolute;right:.55rem;bottom:.55rem;background:rgba(14,17,23,.78);border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:.18rem .48rem;font-size:.66rem;font-weight:900;color:#fff}
.model-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:.45rem}
.model-thumbs button{padding:0;border:1px solid rgba(255,255,255,.14);border-radius:7px;background:transparent;overflow:hidden;cursor:pointer}
.model-thumbs button.active,.model-thumbs button:hover{border-color:var(--red2)}
.model-thumbs img{width:100%;aspect-ratio:4/3;object-fit:cover;background:var(--bg3);display:block}
.model-detail-body{padding:1.55rem;display:grid;align-content:center;gap:.65rem}
.model-detail-body h2{font-size:clamp(1.55rem,3vw,2.5rem);line-height:1.05;margin:.05rem 0 .2rem}
.model-detail-body .desc{font-size:.92rem;line-height:1.75;max-width:62ch}
.model-detail-body .chips{margin:.35rem 0 .15rem;gap:.45rem}
.model-detail-body .mini-chip{font-size:.76rem;padding:.34rem .62rem;border-color:rgba(255,255,255,.16);background:rgba(255,255,255,.065);color:#eef3fb}
.model-price{margin:.3rem 0 .2rem;padding:.68rem .75rem;border:1px solid rgba(255,255,255,.08);border-radius:10px;background:rgba(255,255,255,.026)}
.model-price .price{margin-top:0;font-size:1.12rem}
.model-price .small{font-size:.68rem;line-height:1.45}
.roof-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}
.roof{padding:1.1rem}
.roof-visual{width:100%;display:block;border-radius:10px;margin-bottom:.9rem;background:#fff;border:1px solid rgba(255,255,255,.1)}
.roof-line{height:64px;border-bottom:2px solid rgba(255,255,255,.25);border-radius:50% 50% 0 0;position:relative;margin-bottom:.75rem}
.roof-line::before,.roof-line::after{content:"";position:absolute;background:var(--red);height:6px;border-radius:99px;top:28px}
.railing::before{left:18%;width:26%}.railing::after{right:18%;width:26%}
.fix::before{left:24%;width:8%}.fix::after{right:24%;width:8%}
.normal::before,.normal::after{display:none}
.integrated::before{left:14%;width:70%;height:4px}.integrated::after{display:none}
.form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem}
.field{display:flex;flex-direction:column;gap:.3rem}
.wide{grid-column:1/-1}
label{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.09em;font-weight:900}
input,select,textarea{width:100%;background:rgba(255,255,255,.045);border:1px solid var(--line);border-radius:8px;color:#fff;padding:.72rem .82rem;outline:none}
textarea{min-height:100px;resize:vertical}
input:focus,select:focus,textarea:focus{border-color:var(--red)}
option{background:var(--bg2)}
footer{background:#111;padding:2.4rem 0;border-top:1px solid var(--line);color:var(--muted)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:1.5rem}
.modal{position:fixed;inset:0;background:rgba(0,0,0,.72);display:none;align-items:center;justify-content:center;padding:1rem;z-index:50}
.modal.open{display:flex}
.modal-panel{width:min(880px,100%);max-height:90vh;overflow:auto;background:var(--bg2);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow)}
.modal-head{display:flex;justify-content:flex-end;padding:.8rem;position:sticky;top:0;background:var(--bg2);z-index:2}
.modal-body{padding:0 1.2rem 1.2rem}
.detail-top{display:grid;grid-template-columns:1.1fr .9fr;gap:1rem}
.detail-img{aspect-ratio:16/10;border-radius:12px;overflow:hidden;background:var(--bg3);position:relative}
.detail-img img{width:100%;height:100%;object-fit:cover}
.gallery-btn{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border:1px solid rgba(255,255,255,.25);border-radius:999px;background:rgba(14,17,23,.72);color:#fff;font-size:2rem;line-height:1;display:grid;place-items:center;cursor:pointer;backdrop-filter:blur(8px)}
.gallery-btn:hover{background:var(--red);border-color:var(--red)}
.gallery-prev{left:.75rem}
.gallery-next{right:.75rem}
.gallery-count{position:absolute;right:.75rem;bottom:.75rem;background:rgba(14,17,23,.78);border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:.22rem .55rem;font-size:.72rem;font-weight:800;color:#fff}
.toast{position:fixed;right:1rem;top:5rem;background:var(--card);border:1px solid var(--red);border-radius:8px;padding:.75rem 1rem;transform:translateX(130%);transition:.25s;z-index:80}
.toast.show{transform:none}
.admin-layout{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
.sidebar{background:#10141c;border-right:1px solid var(--line);padding:1rem;position:sticky;top:0;height:100vh}
.admin-main{padding:1.2rem;max-width:1180px;width:100%;margin:auto}
.side-btn{display:flex;width:100%;border:1px solid transparent;background:transparent;color:var(--off);padding:.75rem;border-radius:8px;cursor:pointer;text-align:left;font-weight:800}
.side-btn.active,.side-btn:hover{background:var(--bg3);color:#fff;border-color:var(--line)}
.table{display:grid;gap:.6rem}
.row{display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:10px;padding:.8rem}
.actions{display:flex;gap:.45rem;flex-wrap:wrap}
.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.admin-grid .wide{grid-column:1/-1}
.image-list{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.6rem}
.image-thumb-btn{padding:0;background:transparent;border:0;cursor:pointer;border-radius:8px}
.image-thumb{width:76px;height:58px;border-radius:8px;object-fit:cover;border:2px solid var(--line);display:block}
.image-thumb-btn.active .image-thumb,.image-thumb-btn:hover .image-thumb{border-color:var(--red2)}
.product-image-list figure{margin:0;position:relative}
.product-image-list figcaption{position:absolute;right:4px;bottom:4px;background:rgba(0,0,0,.72);color:#fff;border-radius:999px;font-size:.58rem;font-weight:900;min-width:18px;height:18px;display:grid;place-items:center}
.danger{background:#4b1116;color:#fff}
.muted-panel{background:rgba(255,255,255,.035);border:1px solid var(--line);border-radius:12px;padding:1rem}
.booking-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem;margin-bottom:.9rem}
.mini-stat{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:.85rem}
.mini-stat span{display:block;color:var(--muted);font-size:.68rem;text-transform:uppercase;letter-spacing:.09em;font-weight:900}
.mini-stat strong{display:block;margin-top:.25rem;font-size:1.35rem;color:#fff}
.mini-stat.warn{border-color:#ff4d5a;background:rgba(230,57,70,.12)}
.booking-tabs{display:flex;gap:.45rem;flex-wrap:wrap;margin:0 0 .9rem}
.calendar-filters{display:grid;grid-template-columns:1.2fr .9fr 1fr .8fr auto;gap:.75rem;align-items:end;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:1rem;margin-bottom:1rem}
.calendar-filter-action .btn{height:43px}
.calendar-overview{margin-bottom:1rem;background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.025));border-color:rgba(255,255,255,.16);box-shadow:0 16px 50px rgba(0,0,0,.22)}
.calendar-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem;padding-bottom:.9rem;border-bottom:1px solid var(--line)}
.calendar-hero span{display:block;color:var(--red2);font-size:.68rem;text-transform:uppercase;letter-spacing:.14em;font-weight:950}
.calendar-hero strong{display:block;font-size:1.35rem;line-height:1.1;margin:.18rem 0;color:#fff}
.calendar-hero p{margin:0;color:var(--muted);font-size:.78rem}
.calendar-mode-switch{display:inline-flex;gap:.25rem;background:rgba(0,0,0,.24);border:1px solid var(--line);border-radius:10px;padding:.25rem;white-space:nowrap}
.calendar-mode{border:0;border-radius:8px;background:transparent;color:var(--muted);font-weight:900;font-size:.72rem;padding:.5rem .7rem;cursor:pointer}
.calendar-mode:hover,.calendar-mode.active{background:var(--red);color:#fff}
.calendar-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.35rem}
.calendar-head span{color:var(--muted);font-size:.74rem;font-weight:800}
.calendar-legend{display:flex;gap:.5rem;flex-wrap:wrap;margin:.35rem 0 1rem}
.calendar-legend span{display:inline-flex;align-items:center;gap:.35rem;border:1px solid var(--line);border-radius:999px;padding:.22rem .52rem;color:var(--off);font-size:.68rem;font-weight:800;background:rgba(255,255,255,.035)}
.calendar-legend i{width:10px;height:10px;border-radius:999px;display:inline-block}
.calendar-month-grid{display:grid;gap:.9rem}
.three-month-grid{grid-template-columns:repeat(3,minmax(260px,1fr))}
.single-month-grid{grid-template-columns:1fr}
.single-month-grid .calendar-month-card{min-height:260px}
.calendar-month-card{background:rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:.85rem;overflow:hidden}
.month-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:.55rem}
.month-card-head span{display:block;color:var(--muted);font-size:.65rem;font-weight:900;letter-spacing:.1em;text-transform:uppercase}
.month-card-head strong{font-size:.95rem;color:#fff;text-transform:capitalize}
.month-card-head em{font-size:.68rem;font-style:normal;color:var(--off);border:1px solid var(--line);border-radius:999px;padding:.18rem .45rem;background:rgba(255,255,255,.04);white-space:nowrap}
.month-days{display:grid;grid-template-columns:repeat(31,minmax(8px,1fr));gap:2px;margin:.45rem 0 .55rem;color:var(--muted);font-size:.52rem;border-top:1px solid rgba(255,255,255,.06);padding-top:.45rem}
.month-days span{text-align:center}
.month-bars{display:grid;grid-template-columns:repeat(31,minmax(8px,1fr));gap:.28rem 2px;grid-auto-rows:minmax(24px,auto)}
.calendar-week-grid{display:grid;grid-template-columns:1fr;gap:.85rem}
.calendar-week-card{background:rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:.85rem;overflow:hidden}
.week-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:.65rem}
.week-card-head span{display:block;color:var(--muted);font-size:.65rem;font-weight:900;letter-spacing:.1em;text-transform:uppercase}
.week-card-head strong{font-size:.95rem;color:#fff}
.week-card-head em{font-size:.68rem;font-style:normal;color:var(--off);border:1px solid var(--line);border-radius:999px;padding:.18rem .45rem;background:rgba(255,255,255,.04);white-space:nowrap}
.week-days{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem;margin-bottom:.5rem}
.week-days span{display:grid;gap:.05rem;place-items:center;border:1px solid rgba(255,255,255,.08);border-radius:7px;padding:.3rem;background:rgba(255,255,255,.035)}
.week-days b{font-size:.64rem;color:#fff}
.week-days small{font-size:.62rem;color:var(--muted)}
.week-bars{display:grid;grid-template-columns:repeat(7,1fr);gap:.35rem .25rem;grid-auto-rows:minmax(28px,auto)}
.booking-bar{min-width:0;border:0;border-left:4px solid var(--bar);border-radius:8px;background:rgba(255,255,255,.08);color:#fff;padding:.25rem .45rem;text-align:left;cursor:pointer;overflow:hidden;box-shadow:0 4px 14px rgba(0,0,0,.18)}
.booking-bar:hover,.booking-bar.active{outline:1px solid var(--bar);background:rgba(255,255,255,.16);transform:translateY(-1px)}
.booking-bar span,.booking-bar small{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.booking-bar span{font-size:.68rem;font-weight:950}
.booking-bar small{font-size:.58rem;color:rgba(255,255,255,.78);margin-top:.04rem}
.undated-requests{display:grid;gap:.45rem;margin-top:.9rem;border-top:1px solid var(--line);padding-top:.75rem}
.calendar-request{display:grid;grid-template-columns:auto 140px 1fr;gap:.5rem;align-items:center;border:1px solid var(--line);border-radius:9px;background:rgba(255,255,255,.045);color:#fff;text-align:left;padding:.62rem;cursor:pointer}
.calendar-request:hover{border-color:var(--red2);background:rgba(230,57,70,.08)}
.calendar-request .dot{width:10px;height:10px;border-radius:999px}
.calendar-request span{font-weight:900}
.calendar-request em{color:var(--muted);font-size:.72rem;font-style:normal}
.booking-layout{grid-template-columns:minmax(360px,.9fr) minmax(420px,1.1fr);gap:1rem;min-height:auto}
.booking-list{display:grid;gap:.6rem;margin-bottom:1rem}
.booking-row{display:grid;grid-template-columns:1fr auto;gap:.75rem;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:10px;padding:.8rem;cursor:pointer}
.booking-row:hover,.booking-row.active{border-color:var(--red2);background:rgba(230,57,70,.08)}
.booking-row-top{display:flex;gap:.55rem;align-items:center;justify-content:space-between;margin-bottom:.25rem}
.status-pill{border:1px solid var(--line);border-radius:999px;padding:.18rem .5rem;font-size:.66rem;font-weight:900;color:#fff;background:rgba(255,255,255,.06);white-space:nowrap}
.status-confirmed{background:rgba(60,130,246,.2);border-color:rgba(60,130,246,.45)}
.status-pending_confirmation{background:rgba(20,184,166,.22);border-color:rgba(20,184,166,.55);color:#d5fff8}
.status-option,.status-draft,.status-new{background:rgba(139,92,246,.2);border-color:rgba(139,92,246,.45)}
.status-preparing{background:rgba(245,158,11,.2);border-color:rgba(245,158,11,.45)}
.status-handed_over{background:rgba(66,215,125,.2);border-color:rgba(66,215,125,.45)}
.status-cancelled{background:rgba(122,133,153,.18);border-color:rgba(122,133,153,.35)}
.conflict-note{margin-top:.35rem;color:#ff8a94;font-size:.72rem;font-weight:850}
.conflict-panel{display:grid;gap:.55rem;margin-bottom:1rem;border-color:rgba(255,77,90,.42);background:rgba(230,57,70,.08)}
.conflict-row{display:grid;grid-template-columns:1.2fr auto auto 1fr;gap:.55rem;align-items:center;background:rgba(0,0,0,.14);border:1px solid var(--line);border-radius:8px;padding:.55rem}
.conflict-row strong{display:block;font-size:.8rem}
.conflict-row span{display:block;color:var(--muted);font-size:.72rem}
.conflict-row .btn{padding:.45rem .65rem;font-size:.72rem}
.availability-panel{display:grid;gap:.75rem;background:linear-gradient(180deg,rgba(20,184,166,.08),rgba(255,255,255,.035));border:1px solid rgba(20,184,166,.28);border-radius:12px;padding:.9rem;margin:.2rem 0 .35rem}
.availability-panel.muted{background:rgba(255,255,255,.035);border-color:var(--line)}
.availability-panel.muted p{margin:.25rem 0 0;color:var(--muted);font-size:.78rem}
.availability-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}
.availability-head span{display:block;color:#5eead4;font-size:.66rem;text-transform:uppercase;letter-spacing:.12em;font-weight:950}
.availability-head strong{display:block;color:#fff;font-size:1rem;margin-top:.1rem}
.availability-head em{font-style:normal;color:#d5fff8;border:1px solid rgba(20,184,166,.35);background:rgba(20,184,166,.12);border-radius:999px;padding:.22rem .55rem;font-size:.7rem;font-weight:900;white-space:nowrap}
.availability-alert{display:grid;gap:.08rem;border:1px solid var(--line);border-radius:9px;padding:.62rem .72rem}
.availability-alert strong{font-size:.78rem;color:#fff}
.availability-alert span{color:var(--off);font-size:.72rem;line-height:1.35}
.availability-alert.ok{border-color:rgba(66,215,125,.42);background:rgba(66,215,125,.12)}
.availability-alert.danger{border-color:rgba(255,77,90,.55);background:rgba(230,57,70,.13)}
.availability-groups{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.45rem}
.availability-groups div{background:rgba(0,0,0,.16);border:1px solid rgba(255,255,255,.09);border-radius:9px;padding:.55rem}
.availability-groups span{display:block;color:var(--muted);font-size:.64rem;font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.availability-groups strong{display:block;color:#fff;margin-top:.12rem;font-size:1rem}
.availability-columns{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.availability-columns h4{margin:0 0 .45rem;color:#fff;font-size:.78rem}
.availability-row{display:grid;grid-template-columns:auto 1fr;gap:.5rem;align-items:flex-start;border:1px solid var(--line);border-radius:9px;padding:.58rem;margin-bottom:.42rem;background:rgba(255,255,255,.04)}
.availability-row.free{border-color:rgba(66,215,125,.28)}
.availability-row.busy{border-color:rgba(255,77,90,.28);background:rgba(230,57,70,.07)}
.availability-row i{width:10px;height:10px;border-radius:999px;margin-top:.25rem}
.availability-row strong{display:block;color:#fff;font-size:.76rem}
.availability-row span{display:block;color:var(--muted);font-size:.68rem;line-height:1.35;margin-top:.08rem}
.price-panel{display:flex;align-items:center;justify-content:space-between;gap:1rem;border:1px solid rgba(60,130,246,.35);background:rgba(60,130,246,.09);border-radius:12px;padding:.85rem;margin:.2rem 0}
.price-panel.muted{display:block;border-color:var(--line);background:rgba(255,255,255,.035)}
.price-panel span{display:block;color:#93c5fd;font-size:.66rem;text-transform:uppercase;letter-spacing:.12em;font-weight:950}
.price-panel strong{display:block;color:#fff;margin:.12rem 0;font-size:1.05rem}
.price-panel p{margin:0;color:var(--muted);font-size:.72rem;line-height:1.35}
.price-panel em{display:block;margin-top:.28rem;color:#ffd166;font-style:normal;font-size:.72rem;font-weight:850}
.price-panel.manual{border-color:rgba(245,158,11,.45);background:rgba(245,158,11,.1)}
.booking-calendar{display:grid;gap:.75rem}
.month-block{display:grid;gap:.4rem;border-top:1px solid var(--line);padding-top:.65rem}
.month-title{font-size:.72rem;color:var(--red2);font-weight:950;letter-spacing:.12em;text-transform:uppercase}
.calendar-line{display:grid;grid-template-columns:52px 1fr;gap:.18rem .55rem;align-items:center;border-left:3px solid rgba(255,255,255,.18);background:rgba(255,255,255,.035);border-radius:8px;padding:.45rem .55rem;cursor:pointer}
.calendar-line:hover,.calendar-line.active{background:rgba(230,57,70,.1);border-top-color:rgba(230,57,70,.35);border-right-color:rgba(230,57,70,.35);border-bottom-color:rgba(230,57,70,.35)}
.calendar-line span{color:#fff;font-weight:900;font-size:.72rem}
.calendar-line strong{font-size:.78rem}
.calendar-line em{grid-column:2;color:var(--muted);font-size:.7rem;font-style:normal}
.calendar-line small{grid-column:2;color:var(--off);font-size:.68rem}
.status-left-confirmed{border-left-color:#3c82f6}
.status-left-pending_confirmation{border-left-color:#14b8a6}
.status-left-option,.status-left-draft,.status-left-new{border-left-color:#8b5cf6}
.status-left-preparing{border-left-color:#f59e0b}
.status-left-handed_over{border-left-color:#42d77d}
@media(max-width:800px){
  .nav-links{display:none}.detail-top,.model-detail,.form,.footer-grid,.admin-layout,.admin-grid,.booking-layout,.booking-stats,.calendar-filters,.conflict-row,.three-month-grid,.single-month-grid{grid-template-columns:1fr}.calendar-hero{flex-direction:column}.calendar-mode-switch{width:100%;display:grid;grid-template-columns:repeat(3,1fr)}.sidebar{height:auto;position:relative}.wide{grid-column:auto}.detail-page-head{display:grid;align-items:start}.model-gallery{border-right:0;border-bottom:1px solid var(--line)}.model-detail-body{padding:1.15rem}
}
@media(max-width:560px){
  .detail-page{padding:2.4rem 0}
  .detail-page .container{padding:0 .85rem}
  .detail-page-head{margin-bottom:1rem;gap:.85rem}
  .detail-page-head h1{font-size:2.15rem}
  .detail-page-head .lead{font-size:.9rem;line-height:1.65}
  .model-detail-list{gap:.85rem}
  .model-gallery{padding:.55rem}
  .model-thumbs{grid-template-columns:repeat(4,1fr);gap:.32rem}
  .model-detail-body h2{font-size:1.45rem}
  .model-detail-body .desc{font-size:.84rem;line-height:1.65}
  .model-price .price{font-size:1.25rem}
  .admin-main{padding:.75rem}
  .booking-stats{gap:.5rem}
  .mini-stat{padding:.7rem}
  .calendar-overview{padding:.8rem}
  .calendar-month-card,.calendar-week-card{padding:.7rem}
  .month-days,.week-days{display:none}
  .month-bars,.week-bars{display:flex;flex-direction:column;gap:.45rem}
  .booking-bar,.week-booking-bar{grid-column:auto!important;min-height:42px;padding:.45rem .55rem}
  .booking-bar span{font-size:.78rem}
  .booking-bar small{font-size:.66rem}
  .calendar-request{grid-template-columns:auto 1fr}
  .calendar-request em{grid-column:2}
  .booking-row{grid-template-columns:1fr}
  .booking-row .btn{width:100%}
  .availability-head,.availability-columns{grid-template-columns:1fr;display:grid}
  .availability-head em{justify-self:start}
  .price-panel{display:grid}
  .price-panel .btn{width:100%}
}
