
/* ========== Hostsystem "hsx" – isolated UI (no collision) ========== */
:root{
  --hsx-bg: #0b0c10;
  --hsx-panel: #121826;
  --hsx-text: #e5ecff;
  --hsx-muted: #aab2c0;
  --hsx-border: #2a3144;
  --hsx-accent: #2f7ffc;
  --hsx-accent-2: #7C3AED;
  --hsx-danger: #ef4444;
  --hsx-success: #10b981;
  --hsx-shadow: 0 10px 30px rgba(0,0,0,.25);
}
:root.theme-light{
  --hsx-bg: #ffffff;
  --hsx-panel: #f6f8fc;
  --hsx-text: #0a0c11;
  --hsx-muted: #4b5563;
  --hsx-border: #d9dfeb;
  --hsx-accent: #2f7ffc;
  --hsx-accent-2: #7C3AED;
  --hsx-danger: #dc2626;
  --hsx-success: #059669;
  --hsx-shadow: 0 10px 30px rgba(0,0,0,.12);
}

/* Container / Section */
.hsx-wrap{
  background: var(--hsx-panel);
  color: var(--hsx-text);
  border: 1px solid var(--hsx-border);
  border-radius: 16px;
  box-shadow: var(--hsx-shadow);
  padding: clamp(16px, 3vw, 28px);
  margin: 14px 0;
}
.hsx-header{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:12px; }
.hsx-title{ margin:0; font-weight:800; line-height:1.15; font-size: clamp(1.35rem, 1.2vw + 1rem, 1.9rem); }
.hsx-lead{ margin:.25rem 0 0 0; color: var(--hsx-muted); font-size: .98rem; }

/* Grid */
.hsx-grid{ display:grid; gap:12px; grid-template-columns: 1fr; }
@media (min-width: 720px){ .hsx-grid-2{ grid-template-columns: 1fr 1fr; } .hsx-grid-3{ grid-template-columns: repeat(3,1fr);} }

/* Card */
.hsx-card{
  background: color-mix(in srgb, var(--hsx-panel) 96%, transparent);
  border: 1px solid var(--hsx-border);
  border-radius: 14px;
  padding: clamp(12px, 2.2vw, 18px);
}

/* Form */
.hsx-form{ display:grid; gap:12px; }
.hsx-row{ display:grid; gap:12px; grid-template-columns: 1fr; }
@media (min-width: 680px){ .hsx-row-2{ grid-template-columns: 1fr 1fr; } }
@media (min-width: 900px){ .hsx-row-3{ grid-template-columns: 1fr 1fr 1fr; } }
.hsx-field{ display:grid; gap:6px; }
.hsx-label{ font-weight:600; font-size:.95rem; color: var(--hsx-muted); }
.hsx-input, .hsx-select, .hsx-textarea{
  width:100%; background:#0f131d; color:var(--hsx-text);
  border:1px solid var(--hsx-border); border-radius:10px; padding:10px 12px; font:inherit; outline:none;
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
:root.theme-light .hsx-input, :root.theme-light .hsx-select, :root.theme-light .hsx-textarea{
  background:#fff; color:#0a0c11; border-color: var(--hsx-border);
}
.hsx-input::placeholder, .hsx-textarea::placeholder{ color: color-mix(in srgb, var(--hsx-muted) 60%, transparent); }
.hsx-input:focus, .hsx-select:focus, .hsx-textarea:focus{
  border-color: var(--hsx-accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--hsx-accent) 20%, transparent);
}

/* Messages */
.hsx-error{ border-color: var(--hsx-danger) !important; }
.hsx-help{ font-size:.85rem; color: var(--hsx-muted); }
.hsx-msg{ font-size:.9rem; margin-top:2px; }
.hsx-msg.error{ color: var(--hsx-danger); }
.hsx-msg.ok{ color: var(--hsx-success); }

/* Buttons */
.hsx-actions{ display:flex; gap:10px; flex-wrap:wrap; align-items:center; }
.hsx-btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:10px 14px; border-radius:10px; cursor:pointer;
  border:1px solid var(--hsx-border); text-decoration:none; white-space:nowrap;
  background: linear-gradient(180deg, color-mix(in srgb, var(--hsx-accent) 16%, transparent), transparent);
  color:var(--hsx-text);
  transition: filter .15s ease, transform .12s ease, box-shadow .15s ease;
}
.hsx-btn:hover{ filter: brightness(1.06); box-shadow: 0 10px 20px rgba(0,0,0,.18); }
.hsx-btn:active{ transform: translateY(1px); }
.hsx-btn.primary{ background: var(--hsx-accent); border-color: color-mix(in srgb, var(--hsx-accent) 60%, var(--hsx-border)); color:#fff; }
.hsx-btn.ghost{ background: transparent; }
.hsx-btn.danger{ background: var(--hsx-danger); color:#fff; border-color: color-mix(in srgb, var(--hsx-danger) 60%, var(--hsx-border)); }

/* Alerts */
.hsx-alert{ padding:10px 12px; border-radius:10px; border:1px solid var(--hsx-border); background: rgba(255,255,255,.04); }
.hsx-alert.ok{ border-color: color-mix(in srgb, var(--hsx-success) 40%, var(--hsx-border)); background: color-mix(in srgb, var(--hsx-success) 14%, transparent); color:#ecfffa; }
.hsx-alert.err{ border-color: color-mix(in srgb, var(--hsx-danger) 40%, var(--hsx-border)); background: color-mix(in srgb, var(--hsx-danger) 14%, transparent); color:#fff1f1; }

/* Contact info block */
.hsx-contact-block{ display:grid; gap:8px; }
.hsx-kv{ display:grid; grid-template-columns: auto 1fr; gap:6px 10px; align-items:center; }
.hsx-kv dt{ color: var(--hsx-muted); }
.hsx-kv dd{ margin:0; }

/* GDPR / cookie mini banner */
.hsx-cookie{
  position: fixed; left: 12px; right: 12px; bottom: 12px; z-index: 9999;
  background: var(--hsx-panel); color: var(--hsx-text);
  border: 1px solid var(--hsx-border); border-radius: 14px; padding: 10px 12px;
  box-shadow: var(--hsx-shadow);
  display:grid; gap:8px;
}
.hsx-cookie .hsx-actions{ justify-content: flex-end; }

/* Utils */
.hsx-center{ text-align:center; }
.hsx-right{ text-align:right; }
.hsx-muted{ color: var(--hsx-muted); }
.hsx-hide{ display:none !important; }
.visually-hidden{ position:absolute !important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0; }

/* === hsx-modal (izolált) === */
.hsx-modal{position:fixed;inset:0;display:none;z-index:10000;}
.hsx-modal[aria-hidden="false"]{display:block;}
.hsx-modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55);}
.hsx-modal__dialog{
  position:relative;margin:10vh auto 0;max-width:min(92vw,520px);
  background:var(--hsx-panel);color:var(--hsx-text);
  border:1px solid var(--hsx-border);border-radius:16px;
  box-shadow:var(--hsx-shadow);padding:16px;
}
.hsx-modal__title{margin:0 0 .35rem 0;font-weight:800;font-size:1.2rem;}
.hsx-modal__body{margin:.25rem 0 .75rem 0;}
.hsx-modal__actions{display:flex;justify-content:flex-end;gap:8px;}
.hsx-modal__close{
  position:absolute;top:10px;right:12px;border-radius:12px;
  width:36px;height:36px;border:1px solid var(--hsx-border);
  background:transparent;color:var(--hsx-text);cursor:pointer;
}
.hsx-hide{display:none !important;}

/* reCAPTCHA v3 – inline disclosure használata esetén a badge elrejtése */
.grecaptcha-badge { visibility: hidden !important; }

/* Opcionális: disclosure stílus a láblécben */
.rc-disclosure{
  font-size:.85rem; 
  opacity:.8;
  margin-top:.5rem;
}
.rc-disclosure a{ text-decoration: underline; }
/* hsx – folyamatban spinner + állapot */
.hsx-loading{display:flex;align-items:center;gap:.6rem;font-weight:600;}
.hsx-spinner{
  display:inline-block;width:16px;height:16px;border-radius:50%;
  border:2px solid currentColor;border-right-color:transparent;
  animation:hsx-spin 0.75s linear infinite;
}
@keyframes hsx-spin{to{transform:rotate(360deg)}}
/* Newsletter sor: input + gomb egy vonalban */
#nl-form .hsx-row{
  display: grid;
  grid-template-columns: 1fr auto; /* input nyúlik, gomb fix */
  gap: 12px;
  align-items: center; /* függőlegesen középre igazít */
}

/* ha a gombnál inline style volt (align-items:flex-end), írjuk felül */
#nl-form .hsx-actions{
  align-items: center !important;
  display: flex;
}

/* egységes magasság */
#nl-form .hsx-input{
  height: 44px;
}
#nl-form .hsx-btn{
  height: 44px;
  display: inline-flex;
  align-items: center;
  padding: 0 16px;
  white-space: nowrap;
}

/* Mobilon egymás alá törik szépen */
@media (max-width: 560px){
  #nl-form .hsx-row{
    grid-template-columns: 1fr;
  }
  #nl-form .hsx-btn{
    width: 100%;
    justify-content: center;
  }
}
#quote-form .hsx-row-2{ display:grid; grid-template-columns: 1fr 1fr; gap:12px; }
@media (max-width: 760px){ #quote-form .hsx-row-2{ grid-template-columns: 1fr; } }
#quote-form .hsx-actions{ display:flex; align-items:center; gap:12px; }
#quote-form .hsx-input{ height:44px; }
#quote-form .hsx-btn{ height:44px; display:inline-flex; align-items:center; padding:0 16px; }
/* === Egységes "X" bezáró gomb a HSX modálokra (admin-stílus) === */
:root{
  --hsx-x-size: 36px;
  --hsx-x-fg: #e11d48;          /* piros (adminhoz hasonló) */
  --hsx-x-bg: transparent;          /* fehér háttér */
  --hsx-x-bg-hover: #ffe4e6;    /* halovány rózsaszín hover */
  --hsx-x-ring: rgba(59,130,246,.45);
}

.hsx-modal__dialog { position: relative; }

.hsx-modal__close{
  position: absolute;
  top: 10px;
  right: 10px;
  width: var(--hsx-x-size);
  height: var(--hsx-x-size);
  border-radius: 9999px;
  border: 2px solid var(--hsx-x-fg);
  background: var(--hsx-x-bg);
  color: var(--hsx-x-fg);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  line-height: 1;
  transition: background-color .15s ease, transform .12s ease, box-shadow .15s ease, opacity .15s ease;
  outline: none;
  box-shadow: 0 4px 16px rgba(0,0,0,.25);
}

/* Ha a gombban „×” karakter van, lefedjük egy egységes X-szel */
.hsx-modal__close::before,
.hsx-modal__close::after{
  content: "";
  position: absolute;
  width: 16px;
  height: 2px;
  background: currentColor;
  border-radius: 1px;
}
.hsx-modal__close::before{ transform: rotate(45deg); }
.hsx-modal__close::after { transform: rotate(-45deg); }

/* Ha SVG-t használsz a gombban, az is rendben – ne zavarjon a pseudo-X */
.hsx-modal__close svg{ width:18px; height:18px; pointer-events:none; }

/* Hover/active/focus */
.hsx-modal__close:hover{ background: var(--hsx-x-bg-hover); transform: scale(1.04); }
.hsx-modal__close:active{ transform: scale(0.98); }
.hsx-modal__close:focus-visible{ box-shadow: 0 0 0 3px var(--hsx-x-ring); }

/* Kisebb kijelzőn kicsit nagyobb tappolható felület */
@media (max-width: 480px){
  :root{ --hsx-x-size: 40px; }
  .hsx-modal__close::before, .hsx-modal__close::after{ width: 18px; }
}
.hsx-file{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.hsx-file__input{ 
  position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0 0 0 0); 
  white-space:nowrap; border:0; padding:0; margin:-1px; /* képernyőolvasó-barát rejtés */
}
.hsx-file .hsx-btn{ height:44px; padding:0 16px; }
.hsx-file__names{ color: var(--hsx-muted); font-size:.95rem; }
.hsx-file{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.hsx-file .hsx-btn{ height:44px; padding:0 16px; }
.hsx-file__input{
  position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0 0 0 0);
  white-space:nowrap; border:0; padding:0; margin:-1px;
}
.hsx-file__names{ color: var(--hsx-muted); font-size:.95rem; }

.hsx-file__list{
  width:100%; margin:.35rem 0 0; padding:0; list-style:none;
  display:grid; grid-template-columns: 1fr auto; gap:.25rem .75rem;
}
.hsx-file__list li{ display:contents; }
.hsx-file__list .name{ color:#e5e7eb; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.hsx-file__list .size{ color:#9ca3af; text-align:right; }

.hsx-file__total{
  width:100%; margin-top:.25rem; font-size:.92rem;
  color:#cbd5e1;
  text-align: right;
}
.hsx-file.is-over .hsx-file__total{ color:#f87171; font-weight:600; } /* piros, ha túl nagy */
/* Konténer és rejtett input maradhat a korábbi */
.hsx-file{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.hsx-file .hsx-btn{ height:44px; padding:0 16px; }
.hsx-file__input{
  position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0 0 0 0);
  white-space:nowrap; border:0; padding:0; margin:-1px;
}
.hsx-file__names{ color: var(--hsx-muted); font-size:.95rem; }

/* Részletes lista, soronként: Név • Méret • Törlés */
.hsx-file__list{
  width:100%; margin:.35rem 0 0; padding:0; list-style:none;
  display:flex; flex-direction:column; gap:6px;
}
.hsx-file__row{
  display:grid; grid-template-columns: 1fr auto auto; align-items:center;
  gap:.75rem;
  padding:.45rem .6rem;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius:10px;
}
.hsx-file__row .name{
  color:#e5e7eb; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.hsx-file__row .size{
  color:#9ca3af; font-variant-numeric: tabular-nums;
}
.hsx-file__remove{
  appearance:none; border:0; cursor:pointer;
  width:28px; height:28px; border-radius:8px;
  background: rgba(239,68,68,.12); color:#fca5a5;
  display:inline-flex; align-items:center; justify-content:center;
  transition: filter .15s ease, transform .12s ease, background-color .15s ease;
}
.hsx-file__remove:hover{ filter:brightness(1.05); background: rgba(239,68,68,.2); }
.hsx-file__remove:active{ transform: scale(.98); }
.hsx-file__remove::before{
  content: "×"; font-weight:700; line-height:1; font-size:16px;
}

.hsx-file__total{
  width:100%; margin-top:.25rem; font-size:.92rem; color:#cbd5e1;
}

/* Mobilon picit feszesebb */
@media (max-width:480px){
  .hsx-file__row{ grid-template-columns: 1fr auto 28px; gap:.5rem; }
  .hsx-file .hsx-btn{ height:40px; padding:0 14px; }
}
/* --- Fájllista soros elrendezéssel --- */
.hsx-file__list{
  width:100%;
  margin:.5rem 0 0;
  padding:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:8px;
}

/* Asztali: egy sorban név | méret | törlés */
.hsx-file__row{
  display:grid;
  grid-template-columns: minmax(180px, 1fr) auto 32px; /* név rugalmas, méret auto, X fix */
  align-items:center;
  column-gap:12px;
  padding:.5rem .65rem;
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:10px;
}

.hsx-file__row .name{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  color:#e5e7eb;
}
.hsx-file__row .size{
  color:#9ca3af;
  font-variant-numeric: tabular-nums;
  white-space:nowrap;
  justify-self:end;
}

.hsx-file__remove{
  appearance:none; border:0; cursor:pointer;
  width:32px; height:32px; border-radius:10px;
  background: rgba(239,68,68,.12); color:#fca5a5;
  display:inline-flex; align-items:center; justify-content:center;
  transition: filter .15s ease, transform .12s ease, background-color .15s ease;
}
.hsx-file__remove:hover{ filter:brightness(1.05); background: rgba(239,68,68,.2); }
.hsx-file__remove:active{ transform: scale(.98); }
.hsx-file__remove::before{ content:"×"; font-weight:700; font-size:16px; line-height:1; }

/* --- Mobil finomhangolás --- */
@media (max-width: 520px){
  /* két soros, grid-area-val: 
     1. sor: Név ............. [X]
     2. sor: Méret ........... [X]  (X jobbra marad) */
  .hsx-file__row{
    grid-template-columns: 1fr 32px;
    grid-template-areas:
      "name remove"
      "size remove";
    row-gap:4px;
    column-gap:10px;
    padding:.45rem .55rem;
  }
  .hsx-file__row .name{ 
    grid-area:name;
    white-space:normal;                /* törhet */
    display:-webkit-box;               /* max 2 sor */
    -webkit-line-clamp:2;
    -webkit-box-orient: vertical;
  }
  .hsx-file__row .size{ 
    grid-area:size; 
    justify-self:start; 
    opacity:.9;
  }
  .hsx-file__remove{ grid-area:remove; justify-self:end; }
}

/* kisebb tappolható gomb mobilon */
@media (max-width: 380px){
  .hsx-file__remove{ width:28px; height:28px; border-radius:8px; }
}

