:root{
  --green:#13B88A; --green-dark:#0E9B73;
  --coral:#FF6B5C; --coral-dark:#F0584A; --coral-light:#FF9C8F;
  --yellow:#FFC83D;
  --ink:#1C2B33; --gray:#5C6B72; --gray-faint:#9AA6AB;
  --line:#EEF2F0; --mint:#E8F7F1; --bg:#F1F5F3; --white:#FFFFFF;
}
*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{ background:#E9EEEC; font-family:'Nunito',system-ui,sans-serif; color:#1C2B33; -webkit-font-smoothing:antialiased; }
/* FocusOnNavigate az első h1-re tabindex=-1-et tesz és odaviszi a fókuszt; a programozott fókusznak ne legyen látható kerete (a billentyűzetes fókusz megmarad a valódi interaktív elemeken). */
[tabindex="-1"]:focus{ outline:none; }
h1,h2,h3{ font-family:'Quicksand',sans-serif; }
::selection{ background:#FFE3A3; }

.ut-shell{ max-width:440px; margin:0 auto; background:#FFFFFF; min-height:100vh; position:relative; overflow-x:clip; padding-bottom:84px; box-shadow:0 0 60px rgba(28,43,51,0.08); }
.ut-header{ position:sticky; top:0; z-index:40; background:rgba(255,255,255,0.92); backdrop-filter:blur(10px); border-bottom:1px solid #EEF2F0; padding:12px 18px; display:flex; align-items:center; justify-content:space-between; }
.ut-bottombar{ position:fixed; left:50%; transform:translateX(-50%); bottom:0; width:100%; max-width:440px; z-index:50; background:rgba(255,255,255,0.96); backdrop-filter:blur(10px); border-top:1px solid #EEF2F0; padding:10px 14px calc(10px + env(safe-area-inset-bottom)); display:flex; gap:10px; }

.ut-scroll::-webkit-scrollbar{ height:6px; }
.ut-scroll::-webkit-scrollbar-thumb{ background:#D7DEDB; border-radius:99px; }

.ut-btn{ text-decoration:none; font-weight:800; border-radius:999px; display:inline-flex; align-items:center; justify-content:center; gap:8px; cursor:pointer; border:none; transition:background .15s, border-color .15s, transform .1s; }
.ut-btn:active{ transform:scale(0.985); }
.ut-btn-primary{ background:#FF6B5C; color:#fff; box-shadow:0 6px 16px rgba(255,107,92,0.34); }
.ut-btn-primary:hover{ background:#F0584A; }
.ut-btn-call{ background:#fff; color:#0E9B73; border:2px solid #C9EADD; }
.ut-btn-call:hover{ border-color:#13B88A; }
.ut-btn-call-solid{ background:#13B88A; color:#fff; }
.ut-btn-call-solid:hover{ background:#0E9B73; }
.ut-chip-call{ background:#E8F7F1; color:#0E9B73; }
.ut-chip-call:hover{ background:#D6F0E6; }

.ut-vcard{ transition:transform .15s, box-shadow .15s; }
.ut-vcard:hover{ transform:translateY(-2px); box-shadow:0 8px 20px rgba(28,43,51,0.10); }

details.ut-faq summary{ list-style:none; }
details.ut-faq summary::-webkit-details-marker{ display:none; }
.ut-faq-plus{ transition:transform .15s; display:inline-block; }
details.ut-faq[open] .ut-faq-plus{ transform:rotate(45deg); }

.ut-input{ width:100%; font-weight:700; font-size:15px; color:#1C2B33; background:#fff; border:2px solid #E1E7E4; border-radius:12px; padding:13px 14px; outline:none; font-family:'Nunito',sans-serif; }
.ut-input::placeholder{ color:#9AA6AB; font-weight:700; }
.ut-input:focus{ border-color:#13B88A; }

/* Foglalási űrlap: ragadós lépés-sáv + szakaszok */
.ut-formsteps{ position:sticky; top:54px; z-index:30; background:rgba(255,255,255,0.96); backdrop-filter:blur(10px); border-bottom:1px solid #EEF2F0; padding:9px 18px; }
.ut-formsteps-inner{ display:flex; align-items:center; gap:7px; max-width:680px; margin:0 auto; }
.ut-formsteps-line{ flex:1; min-width:12px; height:2px; border-radius:2px; }
.ut-formsteps-sum{ max-width:680px; margin:7px auto 0; text-align:center; font-size:12.5px; font-weight:800; color:#0E9B73; }
.ut-step{ display:flex; align-items:center; gap:7px; flex:none; text-decoration:none; }
.ut-step-num{ width:26px; height:26px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:'Quicksand',sans-serif; font-weight:700; font-size:13px; }
.ut-step-lbl{ font-weight:800; font-size:13px; }
.ut-secnum{ flex:none; width:28px; height:28px; border-radius:50%; background:#E8F7F1; color:#0E9B73; font-family:'Quicksand',sans-serif; font-weight:700; font-size:15px; display:flex; align-items:center; justify-content:center; }
.ut-sectitle{ font-family:'Quicksand',sans-serif; font-weight:700; font-size:18px; margin:0; }

/* Admin menüsor */
.ut-adminnav{ background:#243640; display:flex; gap:2px; padding:0 10px; overflow-x:auto; }
.ut-adminnav a{ display:inline-flex; align-items:center; gap:6px; color:#94A3B0; text-decoration:none; font-weight:800; font-size:13.5px; padding:13px 12px; white-space:nowrap; border-bottom:3px solid transparent; }
.ut-adminnav a svg{ flex:none; }
.ut-adminnav a:hover{ color:#D4F3E8; }
.ut-adminnav a.active{ color:#fff; border-bottom-color:#37D6B0; }

/* GYIK rács: mobilon 1, desktopon 2 oszlop */
.ut-faqgrid{ display:grid; grid-template-columns:1fr; gap:8px; }

/* Vélemény-rotátor: mobilon 1, desktopon 3 kártya egyszerre; a JS váltja a lapokat (fade) */
.ut-reviews-d{ display:grid; grid-template-columns:1fr; gap:12px; }

#blazor-error-ui{ background:lightyellow; bottom:0; box-shadow:0 -1px 2px rgba(0,0,0,0.2); display:none; left:0; padding:0.6rem 1.25rem 0.7rem; position:fixed; width:100%; z-index:1000; }
#blazor-error-ui .dismiss{ cursor:pointer; position:absolute; right:0.75rem; top:0.5rem; }

/* ===== ASZTALI NÉZET (a mobil az alap, ez ráépül) ===== */
@media (min-width:1000px){
  body{ background:#F1F5F3; }

  /* shell + fejléc/lábléc (MainLayout) */
  .ut-shell{ max-width:1140px; padding-bottom:48px; box-shadow:none; overflow:visible; }
  .ut-mobcall, .ut-bottombar{ display:none !important; }
  .ut-header{ padding:16px 30px !important; }
  .ut-nav{ display:flex !important; }
  .ut-footer-d{ display:grid !important; grid-template-columns:1.5fr 1fr 1.2fr; gap:30px; align-items:start; padding:36px 24px 44px !important; }
  .ut-footer-d > div{ margin:0 !important; }

  /* Főoldal */
  .ut-hero{ display:grid !important; grid-template-columns:1.05fr 0.95fr; align-items:center; gap:44px; padding:54px 24px 50px !important; }
  .ut-hero h1{ font-size:48px !important; }
  .ut-hero-img{ height:400px !important; }
  .ut-grid4{ grid-template-columns:repeat(4,1fr) !important; }
  .ut-grid3{ grid-template-columns:repeat(3,1fr) !important; }
  .ut-cardimg{ height:190px !important; }
  .ut-row2{ display:grid !important; grid-template-columns:1fr 1fr; gap:22px; align-items:stretch; padding:20px 24px 4px !important; }
  .ut-row2 > section{ padding:0 !important; }
  .ut-row2 > section > div{ height:100% !important; }
  .ut-reviews-d{ grid-template-columns:repeat(3,1fr) !important; }
  .ut-narrow{ max-width:780px; margin-left:auto; margin-right:auto; }
  .ut-faqgrid{ grid-template-columns:1fr 1fr; gap:8px 12px; align-items:start; }
  .ut-foglalas-d > div{ padding:40px 48px !important; }

  /* Katalógus */
  .ut-cat{ display:grid !important; grid-template-columns:300px 1fr; gap:26px; padding:12px 24px 20px !important; align-items:start; }
  .ut-cat-side{ display:block !important; position:sticky; top:84px; background:#F6FAF8; border:1px solid #EEF2F0; border-radius:18px; padding:14px 14px 16px !important; }
  .ut-cat-main{ display:block !important; }
  .ut-cat-side .ut-scroll{ flex-wrap:wrap !important; overflow:visible !important; }
  .ut-catgrid{ grid-template-columns:repeat(3,1fr) !important; }

  /* Vár-részlet */
  .ut-detail{ display:grid !important; grid-template-columns:1.15fr 0.85fr; column-gap:36px; row-gap:0; padding:24px 24px 10px !important; align-items:start; }
  /* A galéria-cella a felső sor magasságára nyúlik, a kép kitölti — így a kép alja egy vonalban a melletti jellemző-táblázattal. */
  .ut-gcell{ display:flex; flex-direction:column; align-self:stretch; }
  .ut-gcell > section{ flex:1; display:flex; flex-direction:column; }
  .ut-gcell .ut-gal-main{ flex:1 1 auto; height:auto !important; min-height:340px; }
  .ut-d-cell > section{ padding-left:0 !important; padding-right:0 !important; }

  /* Kapcsolat */
  .ut-kap{ display:grid !important; grid-template-columns:1fr 1fr; gap:28px; padding:16px 24px 10px !important; align-items:start; }
  .ut-kap-l, .ut-kap-r{ display:block !important; }
  .ut-kap-l > div, .ut-kap-r > div{ padding-left:0 !important; padding-right:0 !important; }

  /* Foglalás (keskeny, középre zárt) */
  .ut-narrowpage{ max-width:680px; margin-left:auto; margin-right:auto; }
  .ut-formsteps{ top:74px; }
}
