:root{
  --bg:#081120;
  --bg-2:#0f1c33;
  --panel:#ffffff;
  --panel-soft:#f5f8ff;
  --line:#dfe7f5;
  --text:#122033;
  --muted:#627187;
  --accent:#3f7cff;
  --accent-2:#6dd3ff;
  --success:#169b62;
  --danger:#c73b50;
  --warning:#d88911;
  --shadow:0 16px 38px rgba(9,20,40,.12);
  --shadow-strong:0 22px 48px rgba(7,18,39,.22);
  --radius:22px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,Arial,Helvetica,sans-serif;color:var(--text);background:linear-gradient(180deg,#f6f9ff 0%,#eef4ff 100%);line-height:1.55}
a{text-decoration:none;color:inherit}
button,input,textarea,select{font:inherit}
button{cursor:pointer}
.container{width:min(1180px,calc(100% - 32px));margin:0 auto}
.hero{position:relative;padding:28px 0 68px;background:radial-gradient(circle at top left,rgba(109,211,255,.28),transparent 28%),linear-gradient(135deg,#091426 0%,#102341 48%,#153059 100%);color:#fff;overflow:hidden}
.hero::after{content:"";position:absolute;inset:auto -8% -140px auto;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle,rgba(63,124,255,.35),transparent 70%);filter:blur(8px)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 18px;border-radius:18px;margin-bottom:38px}
.glass{background:rgba(255,255,255,.08);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.12)}
.glass-dark{background:rgba(7,18,39,.46);border:1px solid rgba(255,255,255,.12);box-shadow:var(--shadow-strong)}
.brand{display:flex;align-items:center;gap:14px;font-weight:800;font-size:1.08rem}
.logo{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;font-weight:900;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;box-shadow:0 10px 24px rgba(63,124,255,.42)}
.made{font-size:.8rem;opacity:.7;font-weight:500}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:32px;align-items:center}
.eyebrow{display:inline-block;padding:8px 14px;border-radius:999px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.12);font-size:.9rem;font-weight:700;margin-bottom:14px}
h1{font-size:clamp(2rem,4vw,3.65rem);line-height:1.05;margin:0 0 16px}
.hero-lead,.hero p{font-size:1.06rem;color:rgba(255,255,255,.82);max-width:760px}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin:24px 0 18px}
.hero-pills{display:flex;flex-wrap:wrap;gap:12px}
.hero-pills span{padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);font-size:.93rem}
.hero-side{display:flex;justify-content:flex-end}
.booking-preview{padding:26px;border-radius:28px;color:#fff}
.preview-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}
.timeline-preview{display:grid;gap:16px}
.timeline-preview > div{display:grid;grid-template-columns:42px 1fr;gap:14px;align-items:flex-start}
.timeline-preview span{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:grid;place-items:center;font-weight:800}
.timeline-preview b{display:block;margin-bottom:4px}
.timeline-preview small{display:block;color:rgba(255,255,255,.72)}
.section{padding:34px 0}
.section-tight{padding-top:0;margin-top:-24px;position:relative;z-index:2}
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.panel{background:var(--panel);border:1px solid rgba(163,182,212,.18);border-radius:var(--radius);box-shadow:var(--shadow)}
.feature{padding:22px}
.feature b{display:block;font-size:1.04rem;margin-bottom:8px}
.muted{color:var(--muted)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 18px;border-radius:14px;border:1px solid transparent;font-weight:700;transition:.2s ease;background:#fff;color:var(--text)}
.btn:hover{transform:translateY(-1px)}
.btn-accent{background:linear-gradient(135deg,var(--accent),#2f67ef);color:#fff;box-shadow:0 10px 22px rgba(63,124,255,.28)}
.btn-light{background:#fff;color:#0d1b32}
.btn-ghost{background:#eef4ff;color:#163050;border-color:#d8e4ff}
.btn-danger{background:#feecef;color:#8d1f31;border-color:#f7c6cf}
.booking-section{padding-top:18px;padding-bottom:48px}
.booking-form-modern{padding:28px;border-radius:30px}
.panel-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:16px}
.panel-head h2{margin:0 0 6px;font-size:1.55rem}
.stepper{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:26px}
.step{padding:14px 16px;border-radius:18px;background:#f4f8ff;color:#5d6d84;border:1px solid #e3ebfb;font-weight:700;display:flex;align-items:center;gap:10px}
.step span{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:#dfe8fb;color:#29436d;font-size:.92rem}
.step.active{background:linear-gradient(135deg,#1b3160,#274e9b);color:#fff;border-color:transparent;box-shadow:0 12px 24px rgba(24,51,103,.24)}
.step.active span{background:rgba(255,255,255,.16);color:#fff}
.services{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.service{padding:20px;border-radius:22px;border:1px solid #dfe7f5;background:#fff;text-align:left;transition:.2s ease;box-shadow:0 10px 24px rgba(17,34,62,.04)}
.service:hover{transform:translateY(-2px);border-color:#bdd3ff;box-shadow:0 12px 30px rgba(63,124,255,.12)}
.service.selected{border-color:var(--accent);box-shadow:0 0 0 3px rgba(63,124,255,.14), 0 16px 36px rgba(63,124,255,.14);background:linear-gradient(180deg,#ffffff 0%,#f5f9ff 100%)}
.service-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:8px}
.service h3{margin:0;font-size:1.08rem}
.service-chip,.badge{display:inline-flex;align-items:center;justify-content:center;padding:7px 10px;border-radius:999px;font-size:.8rem;font-weight:800}
.service-chip{background:#eef4ff;color:#335089}
.meta{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:12px;color:#4f6078;font-size:.95rem}
.meta b{color:#0f2442}
.calendar-box,.slots-card{background:linear-gradient(180deg,#f8fbff 0%,#f1f6ff 100%);border:1px solid #dfebff;border-radius:26px;padding:18px}
.calendar-box{margin-bottom:18px}
.calendar-toolbar,.slots-head,.actions-inline{display:flex;justify-content:space-between;gap:14px;align-items:center;flex-wrap:wrap}
.calendar-label{font-size:.86rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:800}
.calendar-month{font-size:1.2rem;font-weight:800;color:#102442}
.calendar-legend{display:flex;flex-wrap:wrap;gap:14px;color:#52637a;font-size:.9rem}
.dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:6px}
.dot-available{background:#d4e6ff}
.dot-selected{background:var(--accent)}
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-top:16px}
.calendar-weekday,.calendar-empty{min-height:30px;display:grid;place-items:center;color:#789;font-size:.82rem;font-weight:800}
.calendar-day{min-height:92px;border-radius:20px;border:1px solid #dbe7fb;background:#fff;display:flex;flex-direction:column;align-items:flex-start;justify-content:space-between;padding:12px;transition:.2s ease;box-shadow:0 10px 20px rgba(18,32,51,.04)}
.calendar-day:hover{border-color:#b8cfff;transform:translateY(-2px)}
.calendar-day small{color:#61738b;font-weight:700;text-transform:capitalize}
.calendar-day strong{font-size:1.6rem;color:#122949;line-height:1}
.calendar-day span{font-size:.88rem;color:#52637a;text-transform:capitalize}
.calendar-day.selected{background:linear-gradient(135deg,var(--accent),#4d91ff);border-color:transparent;color:#fff;box-shadow:0 12px 26px rgba(63,124,255,.3)}
.calendar-day.selected small,.calendar-day.selected strong,.calendar-day.selected span{color:#fff}
.slots{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}
.slot{padding:12px 16px;border-radius:14px;border:1px solid #d8e4fb;background:#fff;color:#0f2442;font-weight:800;min-width:86px;transition:.2s ease}
.slot:hover{border-color:#aecaef;transform:translateY(-1px)}
.slot.selected{background:linear-gradient(135deg,#103169,#1f58c7);border-color:transparent;color:#fff;box-shadow:0 10px 22px rgba(29,81,193,.22)}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
label{font-weight:700;color:#233652}
.input,textarea,select{width:100%;border:1px solid #d8e2f2;border-radius:16px;padding:14px 16px;background:#fff;color:#11233c;outline:none;transition:.2s ease}
textarea{min-height:124px;resize:vertical}
.input:focus,textarea:focus,select:focus{border-color:#93b8ff;box-shadow:0 0 0 4px rgba(63,124,255,.12)}
.checkbox-row{display:flex;gap:10px;align-items:flex-start}
.summary{display:grid;gap:10px}
.summary-modern{background:#f6f9ff;border:1px solid #e0e9fb;border-radius:22px;padding:18px}
.summary-row{display:flex;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid #e6eefb}
.summary-row:last-child{border-bottom:0}
.summary-row span{color:#627187}
.summary-row b{text-align:right;color:#102442}
.top-gap{margin-top:18px}
.submit-hint{margin-top:12px}
.hide{display:none!important}
.alert{padding:14px 16px;border-radius:16px;background:#fff5e9;color:#8a5a00;border:1px solid #f3d39c}
.success{padding:26px}
.success-modern{border:1px solid #caefdf;background:linear-gradient(180deg,#fff 0%,#f4fff8 100%)}
.success h2{margin-top:0}
.footer{padding:20px 0 38px;color:#51637b}
.badge-soft{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.1)}
.badge{font-size:.78rem}
.badge.status-new{background:#e8f1ff;color:#2150a0}
.badge.status-confirmed{background:#e7f8f0;color:#15794c}
.badge.status-needs-change{background:#fff5df;color:#b06d00}
.badge.status-cancelled{background:#ffe7eb;color:#a62a41}
.badge.status-completed{background:#edf0f5;color:#46556b}
/* admin */
.admin-layout{display:grid;grid-template-columns:280px 1fr;min-height:100vh}
.sidebar{background:linear-gradient(180deg,#0c1730 0%,#12284c 100%);color:#fff;padding:24px 18px;position:sticky;top:0;height:100vh}
.side-brand{font-size:1.5rem;font-weight:900;margin-bottom:4px}
.side-made{color:rgba(255,255,255,.65);margin-bottom:22px}
.side-menu{display:grid;gap:8px}
.side-menu a{padding:12px 14px;border-radius:14px;color:rgba(255,255,255,.82);font-weight:700}
.side-menu a.active,.side-menu a:hover{background:rgba(255,255,255,.1);color:#fff}
.admin-main{padding:26px}
.admin-top{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:18px}
.admin-top h1{font-size:2rem;color:#102442;margin:0 0 6px}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:18px}
.kpi{padding:18px}
.kpi span{display:block;color:#627187;margin-bottom:8px;font-weight:700}
.kpi strong{font-size:2rem;color:#102442}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:14px 10px;border-bottom:1px solid #e8eef9;vertical-align:top;text-align:left}
.table th{color:#5d6d84;font-size:.92rem}
.actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(135deg,#edf4ff 0%,#f9fbff 100%)}
.login-card{max-width:460px;width:100%;padding:28px}
@media (max-width: 1080px){
  .hero-grid,.features,.kpis,.admin-layout,.grid-2,.services{grid-template-columns:1fr}
  .admin-layout{display:block}
  .sidebar{position:relative;height:auto}
}
@media (max-width: 760px){
  .container{width:min(100% - 24px,100%)}
  .nav{flex-direction:column;align-items:flex-start}
  .stepper{grid-template-columns:1fr 1fr}
  .calendar-grid{grid-template-columns:repeat(2,1fr)}
  .calendar-weekday,.calendar-empty{display:none}
  .calendar-day{min-height:84px}
  .summary-row,.slots-head,.calendar-toolbar,.actions-inline{align-items:flex-start}
}
@media (max-width: 540px){
  .calendar-grid,.stepper{grid-template-columns:1fr}
  .service-top,.summary-row{flex-direction:column;align-items:flex-start}
  .btn{width:100%}
  .hero-actions,.hero-pills{flex-direction:column}
}

/* KR Booking v1.3 - havi naptár + oldalsó idősáv panel */
.calendar-layout{
  display:grid;
  grid-template-columns:minmax(0,1.25fr) minmax(320px,.75fr);
  gap:18px;
  align-items:start;
}
.calendar-nav{display:flex;gap:10px;align-items:center}
.calendar-nav-btn{
  width:44px;height:44px;border-radius:14px;border:1px solid #d9e6fb;background:#fff;color:#102442;
  display:grid;place-items:center;font-size:1.8rem;line-height:1;font-weight:800;box-shadow:0 8px 18px rgba(18,32,51,.06);transition:.2s ease;
}
.calendar-nav-btn:hover{transform:translateY(-1px);border-color:#abc8ff}
.calendar-nav-btn:disabled{opacity:.35;cursor:not-allowed;transform:none}
.calendar-legend-below{margin-top:12px;justify-content:flex-start}
.dot-disabled{background:#d7dde8}
.calendar-month-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}
.calendar-month-grid .calendar-weekday{background:#edf4ff;border-radius:12px;min-height:34px;color:#29436d}
.calendar-month-grid .calendar-day{min-height:86px;align-items:flex-start}
.calendar-day-muted{
  background:#f0f3f9!important;border:1px dashed #d5deec!important;color:#a1adbf;box-shadow:none!important;opacity:.7
}
.calendar-day-muted strong{color:#a1adbf!important;font-size:1.2rem!important}
.calendar-day.disabled{
  background:#f3f5f9;border-color:#e0e5ee;color:#a1adbf;cursor:not-allowed;box-shadow:none;opacity:.78
}
.calendar-day.disabled small,.calendar-day.disabled strong,.calendar-day.disabled span{color:#a1adbf}
.slots-side{position:sticky;top:18px;min-height:514px;display:flex;flex-direction:column}
.slots-head-side{align-items:flex-start}
.slots-vertical{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));align-content:start;max-height:360px;overflow:auto;padding-right:4px}
.slots-vertical .slot{width:100%;min-width:0}
.slots-actions{margin-top:auto;padding-top:18px}
@media (max-width: 980px){
  .calendar-layout{grid-template-columns:1fr}
  .slots-side{position:relative;top:auto;min-height:auto}
  .slots-vertical{grid-template-columns:repeat(3,minmax(0,1fr));max-height:none}
}
@media (max-width: 760px){
  .calendar-month-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:5px}
  .calendar-month-grid .calendar-weekday{display:grid;font-size:.75rem;min-height:28px}
  .calendar-month-grid .calendar-day{min-height:58px;border-radius:12px;padding:7px}
  .calendar-month-grid .calendar-day small,.calendar-month-grid .calendar-day span{display:none}
  .calendar-month-grid .calendar-day strong{font-size:1rem}
  .slots-vertical{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 480px){
  .calendar-toolbar{align-items:flex-start}
  .calendar-nav{width:100%;justify-content:space-between}
  .slots-vertical{grid-template-columns:1fr}
}


/* Dashboard gyors státuszgombok */
.status-button-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.inline-status-form{display:inline-flex;margin:0}
.btn-small{padding:9px 11px;border-radius:12px;font-size:.86rem;white-space:nowrap}
.dashboard-bookings-table td{vertical-align:middle}
@media (max-width: 900px){
  .dashboard-bookings-table{display:block;overflow-x:auto;white-space:nowrap}
  .status-button-row{min-width:420px}
}
