/* ============================
   Csapó Galéria – styles.css
   Rackhost-ready v5 + image-fit (listán is)
   ============================ */

/* ======= Téma és alapok ======= */
:root{
  --bg:#0b1220;
  --bg-soft:#0e1628;
  --card:#0f172a;
  --text:#e2e8f0;
  --muted:#94a3b8;
  --accent:#0ea5e9;
  --accent-2:#22d3ee;
  --ring:0 0 0 3px rgba(14,165,233,.45);

  /* LISTA (rács) KÉPILL. BEÁLLÍTÁS:
     - 'contain' = teljes kép, letterbox háttérrel (NEM vág)
     - 'cover'   = egységes csempék, kitöltés vágással
  */
  --grid-fit: contain;   /* ‹ ha vágást szeretnél a listában: cover */
  --grid-bg:  #fdfeff;   /* letterbox háttér színe */
}
:root.light{
  --bg:#fff;
  --bg-soft:#f7fafc;
  --card:#f1f5f9;
  --text:#0f172a;
  --muted:#475569;
  --accent:#0ea5e9;
  --accent-2:#22d3ee
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial;
  background:var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased
}

/* Képek sose lógjanak túl alapból */
img{max-width:100%;height:auto;display:block}

/* ======= Layout ======= */
.container{max-width:1200px;margin:0 auto;padding:0 20px}

.header{
  position:sticky;top:0;z-index:50;
  background:rgba(11,18,32,.7);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid rgba(148,163,184,.15)
}
.nav{display:flex;align-items:center;gap:20px;height:64px}
.nav .brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--text)}
.nav .brand img{height:28px}
.nav .spacer{flex:1}
.nav a{color: #fff;;text-decoration:none;font-weight:600}
.nav a.active,.nav a:hover{color:green}
.theme-toggle{border:1px solid rgba(148,163,184,.25);background:transparent;color:var(--text);padding:8px 12px;border-radius:12px;cursor:pointer}

.hero .wrap{display:grid;grid-template-columns:1.1fr .9fr;align-items:center;gap:40px;padding:64px 0}
.hero h1{font-size:clamp(28px,4vw,56px);line-height:1.05;margin:0 0 12px}
.hero p{font-size:clamp(16px,2vw,20px);color:var(--muted);margin:0 0 24px}

.cta{display:flex;gap:12px}
.btn{appearance:none;border:none;padding:12px 18px;border-radius:14px;font-weight:700;cursor:pointer}
.btn.secondary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;box-shadow:0 8px 24px rgba(14,165,233,.4)}
.btn.primary {
    background: linear-gradient(201deg, #d10ee961, var(--accent-2));
    color: #fff;
    box-shadow: 0 8px 24px rgba(14, 165, 233, .4);
}.section{padding:48px 0}
.section h2{font-size:clamp(24px,3vw,36px);margin:0 0 16px}
.lead{color:var(--muted)}

.footer{border-top:1px solid rgba(148,163,184,.15);padding:24px 0;color:var(--muted)}

:focus-visible{outline:none;box-shadow:var(--ring)}

/* ======= Grid / Kártyák ======= */
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}
.card{
  grid-column:span 3;
  background:var(--card);
  border:1px solid rgba(148,163,184,.15);
  border-radius:18px;
  overflow:hidden;
  position:relative
}
@media(max-width:1024px){.card{grid-column:span 4}}
@media(max-width:720px){.card{grid-column:span 6}}
@media(max-width:480px){.card{grid-column:span 12}}

/* LISTA: egységes arány + illeszkedés KATTINTÁS NÉLKÜL is */
.card .media{
  position:relative;
  aspect-ratio:1/1;         /* egységes négyzetes vitrin a listában */
  overflow:hidden;
  background:var(--grid-bg);
}
.card .media img{
  width:100%; height:100%;
  /* A lenti változóval szabályozod: contain / cover */
  object-fit:var(--grid-fit);
  object-position:center;
  background:var(--grid-bg); /* letterbox háttér contain esetén */
  transition:opacity .3s ease
}
.card .media img.secondary{
  position:absolute; inset:0; opacity:0
}
.card:hover .media img.secondary{opacity:1}

.card .meta{padding:12px 14px}
.price{font-weight:800}
.brandline{display:flex;justify-content:space-between;align-items:center;gap:8px}

.quick{
  position:absolute;right:12px;bottom:12px;
  background:rgba(11,18,32,.7);color:#fff;
  border:1px solid rgba(148,163,184,.35);
  padding:8px 10px;border-radius:12px;cursor:pointer;
  backdrop-filter:blur(6px)
}
.quick:hover{box-shadow:0 6px 20px rgba(0,0,0,.35)}

/* ======= Modal / Carousel ======= */
.modal{
  position:fixed; inset:0; display:none;
  align-items:center; justify-content:center;
  background:rgba(2,8,23,.6); backdrop-filter:blur(6px); z-index:100
}
.modal.open{display:flex}
.modal .dialog{
  background:var(--bg);
  border:1px solid rgba(148,163,184,.25);
  border-radius:18px;
  width:min(980px,92vw);
  max-height:90vh; overflow:hidden;
  display:grid; grid-template-columns:1fr 1fr
}
@media(max-width:900px){.modal .dialog{grid-template-columns:1fr}}

.carousel{position:relative;background:var(--card)}
.carousel .stage{position:relative;aspect-ratio:1/1;overflow:hidden;background:#0f172a}
.carousel .stage img{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:contain;         /* Gyors nézetben teljes kép (nem vág) */
  object-position:center;
  opacity:0; transition:opacity .35s ease;
  background:#ebebeb;
}
.carousel .stage img.active{opacity:1}

/* Ha a modálban inkább vágjon (tele legyen), cseréld contain -> cover:
.carousel .stage img{ object-fit:cover; object-position:center; }
*/

.carousel .navbtn{
  position:absolute; top:50%; transform:translateY(-50%);
  background:rgba(11,18,32,.6); color:#fff;
  border:1px solid rgba(148,163,184,.35);
  width:38px; height:38px; border-radius:50%;
  display:grid; place-items:center; cursor:pointer
}
.carousel .prev{left:10px}
.carousel .next{right:10px}

.thumbs{
  display:flex; gap:8px; padding:10px;
  overflow-x:auto; background:var(--bg)
}
/* Bélyegek mindig egységesek (crop) */
.thumbs img{
  width:76px; height:76px;
  object-fit:cover; object-position:center;
  border-radius:12px; opacity:.6; cursor:pointer;
  border:2px solid transparent
}
.thumbs img.active{opacity:1;border-color:var(--accent)}

.d-body{padding:16px}
.d-body h3{margin:0 0 6px}
.d-body p{margin:0 0 12px;color:var(--muted)}
.sizes,.colors{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.sizes .opt,.colors .opt{border:1px solid rgba(148,163,184,.25);padding:8px 12px;border-radius:10px;cursor:pointer}
.sizes .opt.active,.colors .opt.active{border-color:var(--accent);background:rgba(14,165,233,.12)}

/* ======= Szűrők ======= */
.filters{display:flex;gap:14px;align-items:flex-start;flex-wrap:wrap;margin:16px 0 24px}
.filter-group{
  display:flex;gap:10px;align-items:center;flex-wrap:wrap;
  background:var(--card);border:1px solid rgba(148,163,184,.15);
  padding:10px 12px;border-radius:14px
}
.filter-group>.title{font-weight:700;color:var(--text);margin-right:6px}
.check{position:relative}
.check input{position:absolute;inset:0;opacity:0;width:0;height:0}
.check label{
  display:inline-flex;align-items:center;gap:6px;
  border:1px solid rgba(148,163,184,.25);
  padding:8px 12px;border-radius:999px;color:var(--muted);
  cursor:pointer;user-select:none
}
.check input:checked+label{
  background:rgba(14,165,233,.12);
  border-color:rgba(14,165,233,.5);
  color:var(--text)
}
.range{display:flex;align-items:center;gap:10px}
.range input[type=range]{width:160px}
.range output{min-width:80px;text-align:right;color:var(--muted)}

.filter-group{max-width:100%}
.filter-group .check{flex:none}
@media(max-width:600px){.filter-group{overflow-x:auto}}

/* ======= Admin előnézethez használható osztály ======= */
.admin-thumb{
  width:88px;height:88px;
  object-fit:cover;object-position:center;
  border-radius:8px;display:block
}
.admin-desc {
  font-size:14px;
  line-height:1.4;
  color:#94a3b8;
  white-space:pre-line;
  max-height:none;      /* nincs limit */
  overflow:visible;     /* teljes szöveg látszik */
}
/* Gépelős/typed effektek gyors letiltása */
.typewriter, .typed, .typed * {
  animation: none !important;
  transition: none !important;
  white-space: normal !important;
  border-right: 0 !important; /* villogó "caret" eltűnik */
}
.typed-cursor { display: none !important; }
.btn.copied {
  position: relative;
  filter: saturate(120%);
}
.btn.copied::after {
  content: '?';
  position: absolute;
  right: -10px;
  top: -10px;
  background: #10b981;
  color: #0b1220;
  width: 22px; height: 22px;
  border-radius: 50%;
  display: grid; place-items: center;
  font-size: 12px; font-weight: 800;
  box-shadow: 0 6px 18px rgba(16,185,129,.35);
  animation: pop .2s ease-out;
}
@keyframes pop { from { transform: scale(.6); opacity: 0 } to { transform: scale(1); opacity: 1 } }

