
:root{
  --custom-ruby:#a60d35;
  --custom-ruby-dark:#641028;
  --custom-pink:#fff4f7;
  --custom-blush:#fde5ed;
  --ruby:var(--custom-ruby);
  --ruby-dark:var(--custom-ruby-dark);
  --pink:var(--custom-pink);
  --blush:var(--custom-blush);
  --ink:#31161f;
  --muted:#6f5962;
  --line:#efd3dc;
  --white:#ffffff;
  --shadow:0 20px 50px rgba(111,20,45,.12);
  --radius:24px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Manrope,Arial,sans-serif;background:linear-gradient(180deg,#fff9fb 0%,#fff 100%);color:var(--ink)}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{width:min(1180px,calc(100% - 36px));margin:0 auto}
.page-shell{min-height:100vh;display:flex;flex-direction:column}
.site-header{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);border-bottom:1px solid rgba(166,13,53,.08)}
.topbar{display:flex;align-items:center;gap:18px;min-height:84px}
.brand{display:flex;align-items:center;gap:14px;min-width:0}
.brand img{width:62px;height:62px;border-radius:50%;box-shadow:0 10px 26px rgba(166,13,53,.18)}
.brand-text{display:flex;flex-direction:column;min-width:0}
.brand-text strong{font-family:"Playfair Display",serif;font-size:30px;line-height:1;color:var(--ruby-dark)}
.brand-text span{font-size:12px;letter-spacing:.18em;text-transform:none;color:var(--muted);font-weight:800}
.main-nav{display:flex;gap:8px;flex-wrap:wrap;margin-left:auto}
.main-nav a{padding:11px 14px;border-radius:999px;font-size:14px;font-weight:700;color:var(--muted)}
.main-nav a.active,.main-nav a:hover{background:var(--blush);color:var(--ruby)}
.header-cta{margin-left:10px}
.button{border:none;border-radius:999px;background:var(--ruby);color:#fff;display:inline-flex;align-items:center;justify-content:center;padding:14px 22px;font-weight:800;font-size:14px;box-shadow:0 10px 20px rgba(166,13,53,.16);cursor:pointer}
.button:hover{transform:translateY(-1px)}
.button.outline{background:#fff;color:var(--ruby);border:1px solid var(--line);box-shadow:none}
.button.full{width:100%}
.page-main{flex:1;padding:30px 0 60px}
.hero{display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:32px;margin:16px auto 36px}
.hero-card{background:linear-gradient(145deg,#fff 0%,#fff5f8 100%);padding:36px;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.eyebrow{margin:0 0 10px;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--ruby);font-weight:900}
.hero-card h1{font-family:"Playfair Display",serif;font-size:clamp(38px,5vw,60px);line-height:.98;margin:0 0 14px;color:var(--ruby-dark)}
.hero-card p{margin:0 0 20px;line-height:1.75;color:var(--muted);font-size:16px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.stats {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 24px;
}

.stat-link {
  display: flex;
  flex-direction: column;
  padding: 12px 16px;
  min-width: 105px;
  border-radius: 16px;
  background: #fff;
  border: 1px solid var(--line);
  color: var(--muted);
  font-size: 14px;
  box-shadow: 0 6px 16px rgba(120, 32, 61, .05);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.stat-link strong {
  color: var(--ink);
  font-size: 20px;
  margin-bottom: 3px;
}

.stat-link:hover {
  transform: translateY(-2px);
  border-color: var(--ruby);
  box-shadow: 0 10px 22px rgba(166, 13, 53, .14);
}

.stat-link:hover strong,
.stat-link:hover span {
  color: var(--ruby);
}
.hero-visual{position:relative}
.hero-visual img{width:100%;border-radius:32px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.8)}
.hero-visual::after{content:"";position:absolute;inset:auto 8% -14px 8%;height:26px;border-radius:50%;background:radial-gradient(circle,rgba(166,13,53,.16),transparent 70%);filter:blur(10px);z-index:-1}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:26px 0 40px}
.quick-card,.panel{background:#fff;border:1px solid var(--line);border-radius:22px;box-shadow:0 8px 24px rgba(120,32,61,.06)}
.quick-card{padding:22px;display:flex;flex-direction:column;gap:10px;transition:.18s ease}
.quick-card:hover{transform:translateY(-2px)}
.quick-card .icon{font-size:26px}
.quick-card h3,.panel h2{font-family:"Playfair Display",serif;color:var(--ruby-dark);margin:0}
.quick-card h3{font-size:28px}
.quick-card p{margin:0;color:var(--muted);line-height:1.6;font-size:14px}
.section-title{display:flex;align-items:end;justify-content:space-between;gap:16px;margin:0 0 20px}
.section-title h2{font-family:"Playfair Display",serif;font-size:38px;color:var(--ruby-dark);margin:0}
.section-title p{margin:0;color:var(--muted);max-width:650px;line-height:1.7}
.two-col{display:grid;grid-template-columns:1.08fr .92fr;gap:24px}
.panel{padding:28px}
.panel p{color:var(--muted);line-height:1.8;font-size:15px}
.info-list{display:grid;gap:12px;margin-top:18px}
.info-item{padding:16px 18px;border-radius:18px;background:var(--pink);border:1px solid var(--line)}
.info-item strong{display:block;color:var(--ruby-dark);margin-bottom:4px}
.contact-card{display:grid;gap:14px}
.contact-card .contact-line{display:flex;align-items:center;gap:10px;font-size:15px;color:var(--muted)}
.preview-image{border-radius:24px;border:1px solid var(--line);box-shadow:var(--shadow);overflow:hidden;background:#fff}
.page-banner{margin-bottom:26px}
.page-banner img{width:100%;border-radius:28px;box-shadow:var(--shadow)}
.price-groups{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.price-card{padding:24px;border-radius:22px;background:#fff;border:1px solid var(--line);box-shadow:0 6px 18px rgba(120,32,61,.06)}
.price-card h3{font-family:"Playfair Display",serif;margin:0 0 18px;color:var(--ruby-dark);font-size:30px}
.price-block{margin-bottom:16px}
.price-block:last-child{margin-bottom:0}
.price-block h4{margin:0 0 10px;color:var(--ruby);font-size:18px}
.price-list{display:grid;gap:10px}
.price-row{display:grid;grid-template-columns:1fr auto;gap:12px;padding-bottom:10px;border-bottom:1px dashed var(--line);font-size:16px}
.price-row:last-child{border-bottom:none;padding-bottom:0}
.price-row span:last-child{font-weight:800;color:var(--ruby-dark);white-space:nowrap}
.notice{margin-top:24px;padding:20px 24px;border-radius:22px;background:linear-gradient(135deg,#fff4f7,#fff);border:1px solid var(--line);box-shadow:0 8px 18px rgba(120,32,61,.06)}
.notice strong{display:block;font-size:22px;color:var(--ruby-dark);margin-bottom:8px;font-family:"Playfair Display",serif}
.rules{display:grid;gap:16px}
.rule{padding:20px 22px;border-radius:20px;background:#fff;border:1px solid var(--line);box-shadow:0 6px 18px rgba(120,32,61,.05)}
.rule h3{margin:0 0 8px;color:var(--ruby-dark);font-size:22px;font-family:"Playfair Display",serif}
.rule p{margin:0;color:var(--muted);line-height:1.7}
.feed-head{display:flex;justify-content:space-between;align-items:end;margin:0 0 18px}
.feed-head h2{font-family:"Playfair Display",serif;color:var(--ruby-dark);font-size:38px;margin:0}
.filters{display:flex;gap:6px;background:#fff;padding:6px;border-radius:999px;border:1px solid var(--line)}
.filter{border:0;background:transparent;padding:10px 16px;border-radius:999px;color:var(--muted);font:700 13px Manrope;cursor:pointer}
.filter.active{color:#fff;background:var(--ruby)}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.tile{height:320px;background:#eee;border-radius:20px;overflow:hidden;position:relative;cursor:pointer;outline:none;box-shadow:0 8px 18px rgba(120,32,61,.06)}
.tile img,.tile video{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}
.tile:hover img,.tile:hover video{transform:scale(1.035)}
.tile:after{content:"";position:absolute;bottom:0;inset-inline:0;height:42%;background:linear-gradient(transparent,rgba(26,9,17,.72))}
.tile-meta{position:absolute;z-index:2;left:14px;right:14px;bottom:13px;color:#fff;display:flex;flex-direction:column;gap:3px}
.tile-meta strong{font-size:14px}.tile-meta span{font-size:11px;opacity:.76}
.play{width:52px;height:52px;border-radius:50%;display:grid;place-items:center;padding-left:3px;background:rgba(255,255,255,.93);color:var(--ruby);position:absolute;z-index:3;left:50%;top:50%;transform:translate(-50%,-50%)}
.empty{min-height:320px;border:1px dashed #ddc2ca;background:#fff;border-radius:22px;display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;padding:35px}
.empty h3{font-family:"Playfair Display",serif;font-size:28px;margin:12px 0 8px;color:var(--ruby-dark)}
.empty p{color:var(--muted);margin:0;line-height:1.7}
.lightbox{position:fixed;z-index:30;inset:0;background:rgba(19,6,12,.88);display:flex;align-items:center;justify-content:center;flex-direction:column;padding:44px}
.lightbox[hidden]{display:none}.lightbox-media{max-width:min(900px,92vw);max-height:78vh}.lightbox img,.lightbox video{max-width:100%;max-height:74vh;border-radius:16px;display:block}.lightbox p{color:#fff;font-weight:700;margin:16px 0 0}.close{position:fixed;right:26px;top:20px;color:#fff;background:none;border:0;font-size:44px;cursor:pointer}
.folder-tools{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-top:16px}.folder-button{cursor:pointer}
.site-footer{background:var(--ruby-dark);color:rgba(255,255,255,.82);margin-top:40px}
.footer-inner{display:flex;justify-content:space-between;gap:20px;align-items:center;min-height:88px;font-size:14px}
.footer-inner a{color:#fff}
.small-meta{font-size:13px;color:var(--muted)}
@media (max-width: 1020px){
  .hero,.two-col,.price-groups{grid-template-columns:1fr}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .topbar{flex-wrap:wrap;padding:12px 0}
  .main-nav{order:3;width:100%;margin-left:0;justify-content:flex-start}
  .header-cta{margin-left:auto}
}
@media (max-width: 640px){
  .container{width:min(100% - 24px,1180px)}
  .brand img{width:52px;height:52px}
  .brand-text strong{font-size:24px}
  .hero-card{padding:24px}
  .grid-4{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr}
  .price-groups{grid-template-columns:1fr}
  .section-title{flex-direction:column;align-items:flex-start}
  .feed-head{align-items:flex-start;flex-direction:column;gap:14px}
  .footer-inner{flex-direction:column;justify-content:center;padding:18px 0}
  .button{width:100%}
  .hero-actions{flex-direction:column}
}
.center-contact {
  display: flex;
  justify-content: center;
  margin-top: 32px;
}

.center-contact .contact-card {
  width: 100%;
  max-width: 500px;
}

/* RubyPureNails betöltő és oldalváltó animáció */
.page-loader{
  position:fixed;
  inset:0;
  z-index:9999;
  display:grid;
  place-items:center;
  padding:24px;
  background:radial-gradient(circle at 50% 32%,#fff 0%,#fff2f6 48%,#f9dfe7 100%);
  opacity:1;
  visibility:visible;
  transition:opacity .45s ease, visibility .45s ease;
}
.page-loader.is-hidden{opacity:0;visibility:hidden;pointer-events:none}
.page-loader-card{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:15px;
  color:var(--ruby-dark);
  text-align:center;
}
.page-loader-logo{
  width:min(168px,42vw);
  aspect-ratio:1;
  object-fit:cover;
  border-radius:50%;
  animation:loader-float 1.7s ease-in-out infinite;
  filter:drop-shadow(0 15px 26px rgba(166,13,53,.18));
}
.page-loader-name{
  font-family:"Playfair Display",serif;
  color:var(--ruby-dark);
  font-size:clamp(26px,4vw,34px);
  font-weight:700;
  letter-spacing:-.03em;
}
.page-loader-line{
  width:150px;
  height:5px;
  border-radius:999px;
  overflow:hidden;
  background:rgba(166,13,53,.13);
}
.page-loader-line::before{
  content:"";
  display:block;
  height:100%;
  width:42%;
  border-radius:inherit;
  background:linear-gradient(90deg,#e46d90,var(--ruby),#c62c59);
  animation:loader-slide .9s ease-in-out infinite alternate;
}
.page-loader-text{font-size:13px;color:var(--muted);font-weight:700;letter-spacing:.08em;text-transform:uppercase}
@keyframes loader-float{
  0%,100%{transform:translateY(0) scale(1)}
  50%{transform:translateY(-7px) scale(1.025)}
}
@keyframes loader-slide{
  from{transform:translateX(-12%)}
  to{transform:translateX(150%)}
}
@media (prefers-reduced-motion: reduce){
  .page-loader-logo,.page-loader-line::before{animation:none}
  .page-loader{transition:none}
}


/* Világos / sötét téma és kapcsolható glitter animáció */
html[data-theme="dark"]{
  --ruby:#ff7da7;
  --ruby-dark:#ffe7ee;
  --pink:#27161f;
  --blush:#351c26;
  --ink:#f7ecf1;
  --muted:#cdb4c0;
  --line:#4a303a;
  --white:#191016;
  --shadow:0 20px 50px rgba(0,0,0,.34);
  color-scheme:dark;
}
html[data-theme="dark"] body{
  background:linear-gradient(180deg,#130b11 0%,#1e1017 45%,#10090e 100%);
}
html[data-theme="dark"] .site-header{
  background:rgba(18,10,15,.92);
  border-bottom-color:rgba(255,125,167,.16);
}
html[data-theme="dark"] .hero-card,
html[data-theme="dark"] .quick-card,
html[data-theme="dark"] .panel,
html[data-theme="dark"] .price-card,
html[data-theme="dark"] .rule,
html[data-theme="dark"] .filters,
html[data-theme="dark"] .empty,
html[data-theme="dark"] .preview-image,
html[data-theme="dark"] .not-found-card,
html[data-theme="dark"] .stat-link{
  background:#1d1218;
}
html[data-theme="dark"] .hero-card{
  background:linear-gradient(145deg,#21131a 0%,#29141e 100%);
}
html[data-theme="dark"] .notice{
  background:linear-gradient(135deg,#25141d,#1d1117);
}
html[data-theme="dark"] .button.outline{
  background:#21141b;
  color:var(--ruby);
}
html[data-theme="dark"] .site-footer{
  background:#0c070b;
}
html[data-theme="dark"] .page-loader{
  background:radial-gradient(circle at 50% 32%,#25141d 0%,#150c12 52%,#0f080c 100%);
}
html[data-theme="dark"] code{
  color:#ffd3e1;
}
.site-controls{
  display:flex;
  align-items:center;
  gap:8px;
  margin-left:10px;
}
.appearance-toggle{
  width:43px;
  height:43px;
  display:inline-flex;
  justify-content:center;
  align-items:center;
  gap:0;
  border:1px solid var(--line);
  background:var(--white);
  color:var(--muted);
  border-radius:999px;
  padding:0;
  font:700 12px Manrope,Arial,sans-serif;
  cursor:pointer;
  transition:transform .18s ease, border-color .18s ease, color .18s ease, background .18s ease;
  white-space:nowrap;
}
.appearance-toggle:hover{
  transform:translateY(-1px);
  color:var(--ruby);
  border-color:var(--ruby);
}
.appearance-toggle[aria-pressed="true"]{
  color:var(--ruby);
  border-color:rgba(166,13,53,.3);
  background:var(--pink);
}
.appearance-toggle.is-off{
  opacity:.72;
}
.toggle-icon{font-size:16px;line-height:1}
.glitter-layer{
  position:fixed;
  z-index:50;
  inset:0;
  pointer-events:none;
  overflow:hidden;
  opacity:1;
  transition:opacity .2s ease;
}
html[data-glitter="off"] .glitter-layer{
  opacity:0;
  visibility:hidden;
}
.glitter{
  position:absolute;
  left:var(--left);
  top:var(--top);
  width:var(--size);
  height:var(--size);
  opacity:0;
  transform:scale(.3) rotate(0deg);
  animation:ruby-glitter var(--duration) var(--delay) ease-in-out infinite;
}
.glitter::before,.glitter::after{
  content:"";
  position:absolute;
  inset:0;
  margin:auto;
  border-radius:999px;
  background:linear-gradient(90deg,transparent,#ffd6e4,transparent);
}
.glitter::before{height:2px;width:100%}
.glitter::after{height:100%;width:2px}
.glitter.sparkle-large{filter:drop-shadow(0 0 7px rgba(255,150,190,.84))}
@keyframes ruby-glitter{
  0%,100%{opacity:0;transform:scale(.3) rotate(0deg)}
  20%{opacity:.15}
  50%{opacity:.92;transform:scale(1) rotate(75deg)}
  76%{opacity:.22}
}
@media (max-width: 1180px){
  .toggle-label{display:none}
  .appearance-toggle{width:43px;justify-content:center;padding:0}
}
@media (max-width: 1020px){
  .site-controls{margin-left:auto}
  .header-cta{margin-left:0}
}
@media (max-width: 640px){
  .site-controls{order:2}
  .header-cta{order:2;width:auto;padding-inline:16px}
}
@media (prefers-reduced-motion: reduce){
  .glitter{animation:none;display:none}
}

/* ----------------------------------------------------------
   Reszponzív finomhangolás – mobil, tablet és nagy képernyő
   ---------------------------------------------------------- */
html,body{max-width:100%;overflow-x:hidden}
body{-webkit-text-size-adjust:100%}
button,a{touch-action:manipulation}
.button,.appearance-toggle,.mobile-menu-toggle,.filter{min-height:44px}
.brand{min-width:0}
.brand-text{min-width:0}
.brand-text strong{overflow-wrap:anywhere}
.main-nav a{min-height:44px;display:inline-flex;align-items:center}
.hero-card,.panel,.quick-card,.price-card,.rule{min-width:0}
.hero-visual img{height:auto;object-fit:cover}
.preview-image img{width:100%;height:auto}
.price-row span:first-child{min-width:0;overflow-wrap:anywhere}
.contact-line{overflow-wrap:anywhere}
.contact-line a{word-break:break-word}
.tile{height:auto;aspect-ratio:4 / 5}
.lightbox{padding:max(22px,env(safe-area-inset-top)) max(14px,env(safe-area-inset-right)) max(22px,env(safe-area-inset-bottom)) max(14px,env(safe-area-inset-left))}
.close{top:max(10px,env(safe-area-inset-top));right:max(12px,env(safe-area-inset-right));width:52px;height:52px;line-height:1}
.mobile-menu-toggle{display:none;width:46px;padding:0;border:1px solid var(--line);border-radius:14px;background:var(--white);color:var(--ruby);align-items:center;justify-content:center;flex-direction:column;gap:5px;cursor:pointer}
.mobile-menu-toggle span{display:block;width:20px;height:2px;background:currentColor;border-radius:2px;transition:transform .18s ease,opacity .18s ease}
.site-header.nav-open .mobile-menu-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.site-header.nav-open .mobile-menu-toggle span:nth-child(2){opacity:0}
.site-header.nav-open .mobile-menu-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
html[data-theme="dark"] .mobile-menu-toggle{background:#21141b}

@media (max-width: 1180px){
  .container{width:min(100% - 32px,1080px)}
  .topbar{gap:12px}
  .main-nav a{padding-inline:11px}
  .header-cta{padding-inline:16px}
  .hero{gap:24px}
}

@media (max-width: 1020px){
  .page-main{padding-top:22px}
  .hero{margin-top:0;gap:22px}
  .hero-visual{max-width:680px;margin-inline:auto}
  .hero-visual img{max-height:540px;object-fit:cover}
  .grid-4{gap:14px}
  .price-card,.panel{padding:24px}
  .gallery{gap:12px}
  .tile{aspect-ratio:4 / 4.7}
}

@media (max-width: 900px){
  .site-header{position:sticky}
  .topbar{
    min-height:0;
    padding:10px 0 12px;
    display:grid;
    grid-template-columns:minmax(0,1fr) auto auto;
    gap:10px;
    align-items:center;
  }
  .brand{grid-column:1;grid-row:1;gap:10px}
  .brand img{width:52px;height:52px}
  .brand-text strong{font-size:clamp(22px,4.3vw,27px)}
  .brand-text span{font-size:10px;letter-spacing:.13em}
  .mobile-menu-toggle{display:inline-flex;grid-column:2;grid-row:1}
  .site-controls{grid-column:3;grid-row:1;display:flex;margin:0;gap:6px}
  .appearance-toggle{width:44px;height:44px;padding:0;justify-content:center}
  .toggle-label{display:none}
  .main-nav{
    grid-column:1 / -1;
    grid-row:2;
    width:100%;
    display:none;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:8px;
    margin:2px 0 0;
    padding:10px;
    background:var(--white);
    border:1px solid var(--line);
    border-radius:18px;
    box-shadow:var(--shadow);
  }
  .site-header.nav-open .main-nav{display:grid}
  .main-nav a{justify-content:center;text-align:center;background:var(--pink);border-radius:12px;padding:12px 8px}
  .header-cta{grid-column:1 / -1;grid-row:3;margin:0;width:100%;padding:13px 16px}
  .hero-card h1{font-size:clamp(40px,9vw,54px)}
  .stats{gap:10px}
  .stat-link{flex:1;min-width:94px}
}

@media (max-width: 720px){
  .container{width:min(100% - 24px,1180px)}
  .page-main{padding:18px 0 44px}
  .hero{display:flex;flex-direction:column;gap:18px;margin-bottom:28px}
  .hero-card{padding:22px;border-radius:20px}
  .hero-card p{font-size:15px;line-height:1.65}
  .hero-visual img{border-radius:22px;max-height:none}
  .hero-actions{gap:10px}
  .hero-actions .button{width:100%}
  .stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));width:100%;margin-top:18px}
  .stat-link{min-width:0;padding:11px 8px;text-align:center;align-items:center}
  .stat-link strong{font-size:19px}
  .stat-link span{font-size:12px}
  .section-title h2,.feed-head h2{font-size:clamp(30px,9vw,36px)}
  .section-title{gap:8px;margin-bottom:16px}
  .grid-4{margin:18px 0 28px}
  .quick-card{padding:19px;border-radius:18px}
  .quick-card h3{font-size:26px}
  .two-col{gap:16px}
  .panel,.price-card,.rule{padding:20px;border-radius:18px}
  .price-card h3{font-size:27px}
  .price-row{font-size:15px}
  .price-row span:last-child{text-align:right}
  .feed-head{margin-bottom:14px}
  .filters{width:100%;display:grid;grid-template-columns:repeat(3,1fr)}
  .filter{padding-inline:6px}
  .gallery{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
  .tile{aspect-ratio:3 / 4;border-radius:16px}
  .tile-meta{left:10px;right:10px;bottom:10px}
  .tile-meta strong{font-size:12px}
  .folder-tools{flex-direction:column;align-items:stretch}
  .folder-tools .button{width:100%;text-align:center}
  .footer-inner{align-items:flex-start;text-align:left;gap:14px;padding:21px 0;min-height:0}
  .page-loader-logo{width:min(132px,38vw)}
}

@media (max-width: 480px){
  .topbar{grid-template-columns:minmax(0,1fr) auto auto;gap:7px}
  .brand img{width:45px;height:45px}
  .brand-text strong{font-size:20px}
  .brand-text span{display:none}
  .mobile-menu-toggle,.appearance-toggle{width:41px;height:41px;min-height:41px}
  .toggle-icon{font-size:15px}
  .main-nav{grid-template-columns:1fr;padding:8px}
  .hero-card{padding:19px}
  .eyebrow{font-size:10px}
  .stats{gap:7px}
  .stat-link{padding:10px 5px}
  .stat-link strong{font-size:18px}
  .stat-link span{font-size:11px}
  .gallery{grid-template-columns:1fr}
  .tile{aspect-ratio:4 / 4.8}
  .page-loader-card{gap:12px}
}

@media (max-width: 360px){
  .container{width:min(100% - 18px,1180px)}
  .brand-text strong{font-size:18px}
  .brand img{width:40px;height:40px}
  .mobile-menu-toggle,.appearance-toggle{width:38px;height:38px;min-height:38px}
  .stats{grid-template-columns:1fr}
}

@media (hover:none){
  .button:hover,.quick-card:hover,.stat-link:hover,.appearance-toggle:hover{transform:none;box-shadow:none}
}

/* Böngészőből használható szerkesztőfelület */
.editor-link{border:1px solid rgba(255,255,255,.25);border-radius:999px;padding:8px 13px;font-weight:700;white-space:nowrap}
.editor-page{padding-top:24px}
.editor-hero{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:end;background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:28px;margin-bottom:22px;box-shadow:var(--shadow)}
.editor-hero h1{font-family:"Playfair Display",serif;color:var(--ruby-dark);font-size:clamp(32px,4vw,46px);margin:0 0 10px}
.editor-hero p:not(.eyebrow){color:var(--muted);line-height:1.65;margin:0;max-width:690px}
.editor-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}
.editor-actions .button{padding:12px 16px;box-shadow:none}
.button.danger{background:transparent;border:1px solid var(--line);color:var(--muted);box-shadow:none}
.file-action{position:relative;overflow:hidden;cursor:pointer}
.file-action input{position:absolute;opacity:0;inset:0;cursor:pointer}
.editor-status{grid-column:1/-1;min-height:22px;font-weight:700;color:var(--ruby)!important;padding-top:2px}
.editor-status.error{color:#bb203c!important}
.editor-layout{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.editor-card{background:var(--white);border:1px solid var(--line);border-radius:22px;padding:23px;box-shadow:0 6px 18px rgba(120,32,61,.06)}
.editor-card.span-full{grid-column:1/-1}
.editor-card h2{font-family:"Playfair Display",serif;color:var(--ruby-dark);font-size:28px;margin:0 0 18px}
.editor-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:17px}
.editor-card-head h2{margin:0}
.editor-grid{display:grid;gap:12px}
.editor-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.editor-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}
.editor-grid.colors{grid-template-columns:repeat(4,1fr);margin-bottom:18px}
.editor-grid label,.repeat-row label,.section-heading label,.rule-editor-row label,.gallery-edit-item label,.group-name{display:grid;gap:6px;color:var(--muted);font-size:12px;font-weight:800}
.span-2{grid-column:span 2}.span-3{grid-column:span 3}
.editor-card input,.editor-card textarea{width:100%;border:1px solid var(--line);border-radius:11px;padding:10px 12px;background:var(--pink);color:var(--ink);font:600 14px Manrope,Arial,sans-serif;resize:vertical}
.editor-card input[type="color"]{height:46px;padding:5px;cursor:pointer}
.editor-card input:focus,.editor-card textarea:focus{outline:2px solid rgba(166,13,53,.22);border-color:var(--ruby)}
.upload-grid{display:grid;grid-template-columns:110px 1fr;gap:12px}
.upload-box{display:grid;gap:8px;color:var(--muted);font-size:12px;font-weight:800;cursor:pointer}
.upload-box input{padding:8px;font-size:11px}
.upload-box img{height:110px;width:100%;object-fit:cover;border-radius:12px;border:1px solid var(--line);background:var(--pink)}
.upload-box:first-child img{width:110px;border-radius:50%}
.helper{color:var(--muted);font-size:13px;line-height:1.6;margin:14px 0 0}
.mini-button{border:1px solid var(--line);background:var(--pink);color:var(--ruby);font:800 13px Manrope;padding:9px 12px;border-radius:999px;cursor:pointer}
.icon-delete{height:38px;width:38px;border:1px solid var(--line);background:transparent;border-radius:999px;color:var(--muted);font-size:22px;line-height:1;cursor:pointer;flex:none}
.repeat-list{display:grid;gap:10px}
.repeat-row{display:grid;grid-template-columns:1fr 1.3fr .85fr auto;gap:8px;align-items:end}
.compact-headings{margin-bottom:18px}
.prices-editor{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.price-editor-card{border:1px solid var(--line);background:var(--pink);border-radius:17px;padding:15px}
.price-editor-card .editor-card-head{margin-bottom:12px}
.group-name{font-size:13px;flex:1}
.price-editor-card .editor-card-head > div{display:flex;gap:6px;align-items:end}
.section-editor{background:var(--white);border:1px solid var(--line);border-radius:13px;padding:11px;margin-top:10px}
.section-heading{display:grid;grid-template-columns:1fr auto auto;gap:7px;align-items:end;margin-bottom:9px}
.section-heading input{padding:8px 10px}
.item-list{display:grid;gap:7px}
.price-edit-row{display:grid;grid-template-columns:1fr 120px auto;gap:7px;align-items:center}
.price-edit-row input{padding:9px 10px;background:var(--pink)}
.editor-subheading{font-size:17px;color:var(--ruby-dark);margin:20px 0 12px}
.rules-editor{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:11px}
.rule-editor-row{display:grid;grid-template-columns:1fr auto;gap:8px;padding:12px;background:var(--pink);border-radius:14px;border:1px solid var(--line)}
.rule-editor-row label:nth-child(2){grid-column:1/2}
.rule-editor-row .icon-delete{grid-row:1;grid-column:2;align-self:end}
.gallery-editor{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:11px;margin-top:17px}
.gallery-edit-item{display:grid;grid-template-columns:1fr auto;gap:8px;background:var(--pink);border:1px solid var(--line);border-radius:14px;padding:10px}
.gallery-edit-item img{height:126px;width:100%;object-fit:cover;border-radius:9px;grid-column:1/-1}
.gallery-edit-item label{grid-column:1}
.gallery-edit-item .icon-delete{grid-column:2;align-self:end}
.empty-editor{grid-column:1/-1;border:1px dashed var(--line);padding:22px;border-radius:14px;text-align:center;color:var(--muted)}
@media (max-width:1020px){.editor-hero{grid-template-columns:1fr}.editor-actions{justify-content:flex-start}.editor-layout,.prices-editor,.rules-editor{grid-template-columns:1fr}.gallery-editor{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.editor-grid.two,.editor-grid.three,.editor-grid.colors,.upload-grid,.gallery-editor{grid-template-columns:1fr}.span-2,.span-3{grid-column:auto}.repeat-row{grid-template-columns:1fr 1fr}.repeat-row .icon-delete{grid-column:2;justify-self:end}.price-edit-row{grid-template-columns:1fr auto}.price-edit-row input:nth-child(2){grid-column:1}.editor-actions .button{width:auto}.editor-hero{padding:20px}}


/* Feltöltött MP3 hangulat zene */
.music-widget{position:fixed;left:18px;bottom:18px;z-index:1100;display:grid;gap:8px;padding:7px;border:1px solid var(--line);border-radius:26px;background:color-mix(in srgb,var(--white) 94%,transparent);box-shadow:0 10px 30px rgba(80,16,38,.16);backdrop-filter:blur(12px)}
.music-controls{display:flex;align-items:center;gap:9px;min-height:46px}
.music-toggle{display:grid;place-items:center;width:46px;height:46px;flex:none;border:0;border-radius:50%;background:var(--ruby);color:#fff;cursor:pointer;font:800 17px Manrope,Arial,sans-serif;box-shadow:0 6px 15px rgba(166,13,53,.24)}
.music-widget.is-playing .music-toggle{background:var(--ruby-dark)}
.music-copy{display:grid;gap:1px;max-width:128px;padding-right:4px}
.music-copy small{color:var(--muted);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.music-copy strong{color:var(--ink);font-size:12px;max-width:128px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.music-volume{display:flex;align-items:center;gap:4px;color:var(--muted);padding-right:5px}
.music-volume input{width:68px;accent-color:var(--ruby)}
.checkbox-field{display:flex!important;align-items:center;gap:9px!important;min-height:48px;padding:10px 12px;border:1px solid var(--line);border-radius:11px;background:var(--pink);font-size:13px!important;color:var(--ink)!important}
.checkbox-field input[type="checkbox"]{width:19px!important;height:19px;padding:0!important;accent-color:var(--ruby);flex:none}
.music-admin-grid input[type="range"]{padding:5px 0;background:transparent;accent-color:var(--ruby)}
.audio-upload-panel{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:16px}
.audio-file-preview{width:100%;padding:10px 12px;border:1px dashed var(--line);border-radius:12px;background:var(--pink)}
.audio-file-preview p{margin:0 0 8px;font-size:13px;color:var(--muted)}
.audio-file-preview audio{width:100%;height:38px}

@media (max-width:600px){.music-widget{left:11px;bottom:11px}.music-copy,.music-volume{display:none}}
