
/* ====== Nova Public Theme v2 (vivid + mobile-first) ====== */
:root{
  --bg: #08090c;
  --bg-grad-1: #0b0e16;
  --bg-grad-2: #0a0d1a;
  --fg: #fff;
  --muted: rgba(255,255,255,.78);
  --glass: rgba(255,255,255,.06);
  --glass-strong: rgba(255,255,255,.12);
  --border: rgba(255,255,255,.18);
  --ring: rgba(34,211,238,.5);
  --fuchsia: #d946ef;
  --violet: #7c3aed;
  --cyan: #22d3ee;
  --emerald: #10b981;
  --danger: #ef4444;
  --radius: 20px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;color:var(--fg);background:radial-gradient(1200px 600px at 20% -10%, #1e1b4bee 0%, transparent 60%),
  radial-gradient(1000px 600px at 110% 10%, #0ea5e97a 0%, transparent 60%),
  linear-gradient(180deg, var(--bg-grad-1), var(--bg-grad-2));
  font:16px/1.6 ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
.container{max-width:1180px;margin-inline:auto;padding-inline:clamp(.9rem,2vw,1.2rem)}
.section{padding:clamp(2.5rem,4vw,4rem) 0; position:relative}
.section+.section:before{content:""; position:absolute; inset:auto 0 100% 0; height:1px; background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent)}

.kicker{letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-size:.72rem}
.h1{font-size:clamp(2rem,6vw,3.6rem); line-height:1.08; font-weight:900; margin:.4rem 0 0}
.h2{font-size:clamp(1.6rem,4vw,2.4rem); line-height:1.15; margin:.25rem 0}
.h3{font-size:clamp(1.05rem,2.5vw,1.25rem); font-weight:700}
.lead{max-width:44rem;margin-top:.6rem;color:rgba(255,255,255,.9)}

.badge{display:inline-flex;align-items:center;gap:.5rem;padding:.45rem .7rem;border-radius:999px;border:1px solid var(--border);background:var(--glass);backdrop-filter: blur(8px)}
.badge.pill{padding:.35rem .6rem;font-size:.82rem}
.badge.neon-fuchsia{box-shadow:0 0 25px #d946ef66 inset, 0 0 22px #d946ef44; border-color:#d946ef77}
.badge.neon-cyan{box-shadow:0 0 25px #22d3ee66 inset, 0 0 22px #22d3ee44; border-color:#22d3ee77}
.badges{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1rem}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;padding:.8rem 1rem;border-radius:14px;border:1px solid var(--border);background:var(--glass);color:#fff;text-decoration:none;cursor:pointer;transition:transform .15s ease, box-shadow .15s ease, border-color .2s}
.btn:hover{transform:translateY(-1px); box-shadow:0 10px 30px rgba(0,0,0,.35)}
.btn:focus-visible{outline:2px solid transparent; box-shadow:0 0 0 3px var(--ring)}
.btn.primary{background:linear-gradient(90deg, #d946ef44, #7c3aed66 55%, #22d3ee44); border-color:#7c3aed88}
.btn.secondary{background:var(--glass);}
.btn.ghost{background:transparent}
.btn.block{width:100%}

.card{border:1px solid var(--border);background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.04));border-radius:var(--radius);overflow:hidden}
.card.shadow{box-shadow:0 30px 80px rgba(0,0,0,.35)}
.card-head{padding:1rem 1rem .5rem}
.card-body{padding:1rem}
.card-title{display:flex;align-items:center;justify-content:space-between;gap:.75rem;font-weight:800}
.card-price{font-weight:800; padding:.35rem .6rem; border-radius:10px; border:1px solid #22d3ee77; background:#22d3ee1f}

.row{display:flex;justify-content:space-between;align-items:center;gap:.8rem;flex-wrap:wrap}
.stack{display:flex;flex-direction:column;gap:1rem}

.grid{display:grid;gap:1rem;grid-template-columns:repeat(12,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
@media (max-width:980px){.grid,.grid-3,.grid-2{grid-template-columns:1fr}}

.item{border:1px solid var(--border);background:var(--glass);border-radius:14px;padding:.9rem 1rem}
.item.ring{outline:2px solid var(--ring)}

/* ===== HERO ===== */
.hero{position:relative;min-height:85vh;display:flex;flex-direction:column;justify-content:flex-end}
.hero .video-wrap{position:absolute;inset:0;z-index:-2;overflow:hidden}
.bg-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero .veil{position:absolute;inset:0;mix-blend-mode:screen;background:
  radial-gradient(1000px 400px at 70% -10%, rgba(217,70,239,.25), transparent 60%),
  radial-gradient(1000px 400px at -10% 20%, rgba(34,211,238,.23), transparent 60%),
  linear-gradient(to bottom, rgba(0,0,0,.45), rgba(0,0,0,.78) 60%, #08090c); z-index:-1}
.hero .content{padding:clamp(6vh,10vh,14vh) 0}
.hero .h1{ text-shadow:0 6px 38px rgba(0,0,0,.8), 0 0 0 #000; }
.hero .accent{ background: linear-gradient(90deg, #fff, #e9d5ff, #a5f3fc); -webkit-background-clip:text; background-clip:text; color:transparent }

/* ===== Pricing & categories ===== */
.section-head{display:flex;align-items:end;gap:1rem;justify-content:space-between;flex-wrap:wrap}
.switch{display:flex;align-items:center;gap:.6rem}
.switch input{appearance:none;width:40px;height:24px;border-radius:999px;background:#222;border:1px solid var(--border);position:relative;cursor:pointer;transition:background .2s}
.switch input:checked{background:#22d3ee44}
.switch input::after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:999px;background:#fff;transition:left .2s}
.switch input:checked::after{left:18px}

.pkg-grid{display:grid;gap:1rem;grid-template-columns:repeat(3,minmax(0,1fr))}
@media (max-width:980px){.pkg-grid{grid-template-columns:1fr}}
.category-col{grid-column:span 6}
@media (max-width:980px){.category-col{grid-column:1}}

/* ===== Gallery ===== */
.gallery{display:grid;grid-template-columns:repeat(6,1fr);gap:.6rem}
@media (max-width:1100px){.gallery{grid-template-columns:repeat(4,1fr)}}
@media (max-width:700px){.gallery{grid-template-columns:repeat(3,1fr)}}
.gallery .thumb{border:1px solid var(--border);border-radius:16px;overflow:hidden;position:relative}
.gallery .thumb img{width:100%;aspect-ratio:1/1;object-fit:cover;transition:transform .3s ease}
.gallery .thumb:hover img{transform:scale(1.04)}

/* ===== Form ===== */
input,textarea,select{width:100%;padding:.8rem 1rem;border-radius:14px;border:1px solid var(--border);background:rgba(0,0,0,.35);color:#fff}
label{display:flex;flex-direction:column;gap:.4rem}
.form-panel{border:1px solid var(--border);background:rgba(0,0,0,.35);border-radius:14px;padding:1rem}
.form-msg{margin-top:.6rem;padding:.65rem .8rem;border-radius:10px;border:1px solid var(--border);background:rgba(255,255,255,.06)}
.form-msg.ok{border-color:#16a34a;color:#16a34a}.form-msg.err{border-color:var(--danger);color:var(--danger)}

/* ===== Sticky mobile total ===== */
.mobile-sticky{position:fixed;left:0;right:0;bottom:.8rem;padding:0 1rem;z-index:60;display:none}
.mobile-sticky-inner{max-width:560px;margin:0 auto;border:1px solid var(--border);background:rgba(0,0,0,.6);backdrop-filter:blur(8px);border-radius:16px;display:flex;justify-content:space-between;align-items:center;padding:.6rem .7rem}
.mobile-total{font-weight:800}
@media (max-width:720px){.mobile-sticky{display:block}}

/* ===== Footer ===== */
.footer{border-top:1px solid var(--border);padding:2rem 0;color:var(--muted)}
.footer a{color:#fff;text-decoration:none}
.footer a:hover{text-decoration:underline}

/* ===== Utilities ===== */
.mt-1{margin-top:.5rem}.mt-2{margin-top:.75rem}.mt-3{margin-top:1rem}.mt-4{margin-top:1.5rem}.mt-6{margin-top:2rem}


/* ====== Animated/desktop upgrades ====== */
.container{max-width:1280px}

.hero .content{display:flex;flex-direction:column;gap:.6rem}
.hero .h1{background-image:linear-gradient(90deg,#fff,#e9d5ff,#a5f3fc,#fff);background-size:200% auto;-webkit-background-clip:text;background-clip:text;color:transparent;animation:shimmer 6s linear infinite}
@keyframes shimmer{0%{background-position:0% 50%}100%{background-position:200% 50%}}

.section .h2{position:relative}
.section .h2::after{content:"";position:absolute;left:0;bottom:-.35rem;width:64px;height:3px;border-radius:3px;background:linear-gradient(90deg,#7c3aed,#22d3ee)}

.card{transition:transform .25s ease, box-shadow .25s ease, border-color .3s ease}
.card:hover{transform:translateY(-4px); box-shadow:0 20px 70px rgba(0,0,0,.45)}

.glow-card{position:relative}
.glow-card::before{pointer-events:none; content:"";position:absolute;inset:-1px;z-index:-1;border-radius:calc(var(--radius) + 1px);
  background:conic-gradient(from 180deg at 50% 50%, rgba(124,58,237,.5), rgba(34,211,238,.4), rgba(124,58,237,.5));
  filter:blur(18px);opacity:.35;transition:opacity .3s}
.glow-card:hover::before{opacity:.6}

.reveal{opacity:0; transform:translateY(12px); transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1; transform:none}

.price-pulse{animation:pulseCyan .75s ease}
@keyframes pulseCyan{0%{text-shadow:0 0 0 rgba(34,211,238,0)}40%{text-shadow:0 0 22px rgba(34,211,238,.9)}100%{text-shadow:0 0 0 rgba(34,211,238,0)}}

.parallax{transform:translateY(var(--py,0px))}

.gallery .thumb{transition:transform .25s ease, box-shadow .25s ease}
.gallery .thumb:hover{transform:translateY(-3px); box-shadow:0 15px 40px rgba(0,0,0,.35)}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.85);display:none;align-items:center;justify-content:center;padding:1rem;z-index:80}
.lightbox.open{display:flex}
.lightbox img{max-width:min(100%,1200px);max-height:88vh;border-radius:16px;border:1px solid var(--border);box-shadow:0 20px 80px rgba(0,0,0,.6);transform:scale(.96);opacity:0;animation:lbIn .25s ease forwards}
@keyframes lbIn{to{transform:scale(1); opacity:1}}
.lightbox .close{position:absolute;top:1rem;right:1rem;background:transparent;border:0;color:#fff;font-size:2rem;cursor:pointer}




/* === v3.5: colorful & masonry per category === */
:root{
  --cat-brollop:#f0abfc;  /* fuchsia-300 */
  --cat-fest:#93c5fd;     /* sky-300 */
  --cat-kalas:#a7f3d0;    /* emerald-200 */
  --cat-ovrigt:#fde68a;   /* amber-200 */
}
/* Subtle sparkling backdrop */
body::before{
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none;
  background-image:
    radial-gradient(2px 2px at 10% 20%, rgba(255,255,255,.18) 30%, transparent 40%),
    radial-gradient(2px 2px at 80% 10%, rgba(255,255,255,.14) 30%, transparent 40%),
    radial-gradient(2px 2px at 70% 70%, rgba(255,255,255,.12) 30%, transparent 40%),
    radial-gradient(2px 2px at 20% 80%, rgba(255,255,255,.10) 30%, transparent 40%);
  animation: twinkle 7s linear infinite;
}
@keyframes twinkle{
  0%{opacity:.4; transform:translateY(0)}
  50%{opacity:.7; transform:translateY(-4px)}
  100%{opacity:.4; transform:translateY(0)}
}

/* Accent ring (static) to make cards stand out */
.accent-ring{position:relative; border-radius:var(--radius);}
.accent-ring::after{pointer-events:none; 
  content:""; position:absolute; inset:-1px; border-radius:inherit;
  padding:1px;
  background: linear-gradient(90deg, rgba(124,58,237,.55), rgba(34,211,238,.45), rgba(217,70,239,.55));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
}
.selected.accent-ring{box-shadow:0 0 0 2px rgba(34,211,238,.6), 0 10px 60px rgba(34,211,238,.25)}

/* Extra neon shadow to make items pop without spinning borders */
.pop-shadow{box-shadow:0 25px 70px rgba(124,58,237,.18), 0 10px 30px rgba(34,211,238,.12)}

/* Category headers with color tags */
.cat-head{display:flex; align-items:center; gap:.6rem; margin:1rem 0 .6rem}
.cat-dot{width:.9rem;height:.9rem;border-radius:999px;display:inline-block}
.cat-title{font-size:1.1rem; font-weight:800}
.cat-brollop .cat-dot{background:var(--cat-brollop)}
.cat-fest .cat-dot{background:var(--cat-fest)}
.cat-kalas .cat-dot{background:var(--cat-kalas)}
.cat-ovrigt .cat-dot{background:var(--cat-ovrigt)}

/* Masonry per category (container is repeated per group) */
.gallery-group{margin:1rem 0 1.6rem}
.gallery.masonry{column-gap:.9rem}
@media (min-width:1200px){.gallery.masonry{column-count:4}}
@media (min-width:900px) and (max-width:1199px){.gallery.masonry{column-count:3}}
@media (min-width:700px) and (max-width:899px){.gallery.masonry{column-count:2}}
@media (max-width:699px){.gallery.masonry{column-count:2}}
.m-item{break-inside: avoid; margin-bottom:.9rem; border:1px solid var(--border); border-radius:16px; overflow:hidden; background:var(--glass); transition:transform .25s ease, box-shadow .25s ease}
.m-item:hover{transform:translateY(-3px); box-shadow:0 15px 40px rgba(0,0,0,.35)}

/* Tilt remains, but toned for stability */
.tilt{transform-style:preserve-3d; will-change:transform}
.tilt .card-head,.tilt .card-body{transform:translateZ(8px)}

/* Discount pop (kept) */
.discount-pop{display:inline-block; padding:.35rem .6rem; border-radius:999px; background:#10b98122; border:1px solid #10b98188; color:#34d399; font-weight:700; transform:scale(.8); opacity:0; animation:popIn .45s ease forwards}
@keyframes popIn{60%{transform:scale(1.08); opacity:1}100%{transform:scale(1)}}


/* Desktop pricing two-column layout */
.grid.pricing{grid-template-columns:repeat(12,minmax(0,1fr))}
.category-col{grid-column: span 8; position:relative; z-index:2}
.summary-col{grid-column: span 4; position:relative; z-index:1}
@media (max-width:980px){
  .grid.pricing{grid-template-columns:1fr}
  .category-col,.summary-col{grid-column:1}
}
.summary-col .card{position:sticky; top:1rem}


/* Ensure decorative layers never block clicks */
.accent-ring::before, .accent-ring::after,
.glow-card::before, .glow-card::after { pointer-events: none !important; }


/* --- FIX: två-kolumners layouter (kontakt/form) --- */
.grid.two {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}
@media (max-width: 900px) {
  .grid.two { grid-template-columns: 1fr; }
}

/* Form: bättre höjder/avstånd */
label { display: flex; flex-direction: column; gap: .35rem; }
input, textarea, select { min-height: 44px; }
textarea { min-height: 120px; }

/* Säkerställ att dekorativa lager inte blockerar innehåll */
.accent-ring::before, .accent-ring::after,
.glow-card::before, .glow-card::after { pointer-events: none !important; }

/* Kontaktkolumn: låt långa ord radbrytas snyggt */
.contact-info { word-break: break-word; }

/* === BG POLISH v3.5.6 === */
body{
  background:
    radial-gradient(1200px 800px at 10% -10%, rgba(217,70,239,.16), transparent 60%),
    radial-gradient(1000px 700px at 110% -5%, rgba(34,211,238,.14), transparent 60%),
    radial-gradient(900px 700px at 40% 120%, rgba(16,185,129,.12), transparent 60%),
    linear-gradient(180deg, #0b0e16 0%, #090c14 55%, #08090c 100%);
  background-attachment: fixed, fixed, fixed, fixed;
}
/* Subtle noise overlay to avoid banding */
body::after{
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.06;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140' viewBox='0 0 140 140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Section glow layers that overlap to hide seams */
.section{position:relative}
.section::before{
  content:""; position:absolute; left:0; right:0; top:-120px; bottom:-120px; pointer-events:none; z-index:-1;
  background:
    radial-gradient(900px 500px at 0% 0%, rgba(124,58,237,.09), transparent 60%),
    radial-gradient(900px 500px at 100% 0%, rgba(34,211,238,.08), transparent 60%);
}


/* === COOL HERO TITLE EFFECT v3.5.7 === */
.hero-title {
  font-size: clamp(2rem, 6vw, 4rem);
  font-weight: 800;
  text-align: center;
  background: linear-gradient(90deg, #ff00cc, #3333ff, #00ffff, #ff00cc);
  background-size: 200% 200%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: gradientFlow 8s ease infinite, shimmer 6s ease-in-out infinite;
  text-shadow: 0 0 20px rgba(255,255,255,0.15),
               0 0 40px rgba(0,255,255,0.2);
  letter-spacing: 1px;
  position: relative;
}

/* Gradient flow animation */
@keyframes gradientFlow {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* Shimmer overlay */
.hero-title::after {
  content: "";
  position: absolute;
  top: 0;
  left: -75%;
  width: 50%;
  height: 100%;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,.4), transparent);
  transform: skewX(-20deg);
  animation: shimmer 6s ease-in-out infinite;
}

@keyframes shimmer {
  0%, 90%, 100% { left: -75%; }
  30%, 60% { left: 125%; }
}


/* === FIXED HERO TITLE EFFECT v3.5.8 === */
.hero-title {
  font-size: clamp(2rem, 6vw, 4rem);
  font-weight: 800;
  text-align: center;
  background: linear-gradient(90deg, #ff00cc, #3333ff, #00ffff, #ff00cc) !important;
  background-size: 200% 200% !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  animation: gradientFlow 8s ease infinite, shimmer 6s ease-in-out infinite;
  text-shadow: 0 0 20px rgba(255,255,255,0.15),
               0 0 40px rgba(0,255,255,0.2);
  letter-spacing: 1px;
  position: relative;
}

@keyframes gradientFlow {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

.hero-title::after {
  content: "";
  position: absolute;
  top: 0;
  left: -75%;
  width: 50%;
  height: 100%;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,.4), transparent);
  transform: skewX(-20deg);
  animation: shimmer 6s ease-in-out infinite;
}

@keyframes shimmer {
  0%, 90%, 100% { left: -75%; }
  30%, 60% { left: 125%; }
}


/* === HERO TITLE HARD OVERRIDE v3.5.9 === */
h1.hero-title {
  font-size: clamp(2rem, 6vw, 4rem);
  font-weight: 900;
  line-height: 1.08;
  text-align: center;
  background-image: linear-gradient(90deg, #ff00cc, #3333ff, #00ffff, #ff00cc) !important;
  background-size: 200% 200% !important;
  background-clip: text !important;
  -webkit-background-clip: text !important;
  color: transparent !important;
  -webkit-text-fill-color: transparent !important;
  animation: none;
  letter-spacing: .5px;
  position: relative;
  isolation: isolate;
}
h1.hero-title::after{
  content: "";
  position: absolute;
  inset: 0;
  left: -75%;
  width: 50%;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,.45), transparent);
  transform: skewX(-20deg);
  animation: none; opacity: 0;
  pointer-events: none;
}


/* Full-bleed cover for YouTube iframe in hero */
.hero .iframe-cover{position:absolute; inset:0; overflow:hidden; z-index:-2}
.hero .iframe-cover iframe{
  position:absolute; top:50%; left:50%;
  width:100vw; height:56.25vw;          /* 16:9 based on viewport width */
  min-width:177.78vh; min-height:100vh; /* ensure cover based on viewport height */
  transform:translate(-50%,-50%);
  pointer-events:none; border:0;
}


/* === Mobile hero fallback + Corner particles === */
/* Hide YouTube iframe on small screens (autoplay/trackers block often) and use poster/gradient via .hero background */
/* Fixed top-right particle canvas that follows scroll */
#cornerParticles{
  position: fixed; top: 0; right: 0; width: 220px; height: 220px;
  z-index: 70; pointer-events: none; mix-blend-mode: screen; opacity: .75;
  -webkit-mask-image: radial-gradient(70% 70% at 65% 35%, #000 70%, transparent 100%);
          mask-image: radial-gradient(70% 70% at 65% 35%, #000 70%, transparent 100%);
}
@media (max-width:700px){ #cornerParticles{ width: 160px; height:160px; } }


/* Ensure YouTube iframe always covers hero (mobile + desktop) */
.hero .iframe-cover{position:absolute; inset:0; overflow:hidden; z-index:-2}
.hero .iframe-cover iframe{
  position:absolute; top:50%; left:50%;
  width:100vw; height:56.25vw;          /* 16:9 from width */
  min-width:177.78vh; min-height:100vh; /* cover from height */
  transform:translate(-50%,-50%);
  pointer-events:none; border:0;
}


/* Corner particles pinned to viewport corner */
#cornerParticles{
  position: fixed !important; top: 8px; right: 8px;
  width: 220px; height: 220px; z-index: 90;
  pointer-events: none; mix-blend-mode: screen; opacity: .8;
}
@media (max-width:700px){ #cornerParticles{ width: 160px; height:160px; } }
