:root{
  --bs-primary:#FF6B3D;
  --bs-primary-600:#F05626;
  --bs-primary-700:#C5411D;
  --bs-secondary:#7C5CFF;
  --bs-secondary-600:#6748FA;
  --bs-secondary-700:#5336E6;
  --bs-success:#22C55E;
  --bs-warning:#EAB308;
  --bs-danger:#EF4444;
  --bs-info:#38BDF8;
  --bs-dark:#0A0F1A;
  --bs-body:#1F2937;
  --bs-muted:#6B7280;
  --bs-bg:#FFFCF8;
  --bs-card:#FFFFFF;
  --bs-border:#EAE7E1;
  --bs-shadow:0 10px 28px rgba(17,24,39,.08);
  --link:#7C5CFF;
  --link-hover:#5336E6;
  --focus:#FCD34D;
  --h1-color:#0B1220;
  --h2-color:#101827;
  --h3-color:#7C2D12;
  --h4-color:#166534;
  --h5-color:#0E7490;
  --h6-color:#0F766E;
  --tint-primary:#FFF1E8;
  --tint-secondary:#EEF2FF;
  --tint-success:#ECFDF5;
  --tint-warning:#FEF3C7;
  --tint-danger:#FEE2E2;
  --tint-info:#E0F7FA;
  --space-1:8px;--space-2:12px;--space-3:16px;--space-4:20px;--space-5:24px;--space-6:28px;--space-7:36px;
  --star:#F59E0B;--star-off:#E5E7EB;
  --price:#111827;--price-accent:#FF6B3D;--price-compare:#9CA3AF;
  --puzzle-gradient:linear-gradient(90deg,#FF6B3D 0%,#FFB347 25%,#7C5CFF 60%,#0EA5A4 100%);
  --craft-gradient:radial-gradient(600px 220px at 15% -20%,rgba(255,107,61,.18),transparent 60%),radial-gradient(500px 200px at 85% -10%,rgba(124,92,255,.15),transparent 62%),radial-gradient(600px 240px at 50% 110%,rgba(14,165,164,.12),transparent 65%);
  --dots:radial-gradient(currentColor 1px,transparent 1px);
  --jelly:clamp(14px,1.4vw,18px);
}

*{box-sizing:border-box}
html,body{height:100%}
html,body,[data-bs-theme]{color-scheme:light!important}
body{
  margin:0;background:var(--bs-bg);color:var(--bs-body);
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,Ubuntu,"Helvetica Neue",Arial,"Noto Sans",sans-serif;
  font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  background-image:
    radial-gradient(700px 260px at 50% -10%,rgba(255,241,232,.7),transparent 70%),
    radial-gradient(500px 200px at -10% 120%,rgba(238,242,255,.8),transparent 70%),
    radial-gradient(600px 260px at 110% 120%,rgba(255,241,232,.6),transparent 72%)
}
a{color:var(--link);text-decoration:underline}
a:hover{color:var(--link-hover);text-decoration:underline}
:focus-visible{outline:3px solid var(--focus);outline-offset:2px}

.container{max-width:1200px;margin:0 auto;padding:0 var(--space-3)}
.row{display:flex;flex-wrap:wrap;margin-left:-12px;margin-right:-12px;row-gap:var(--space-3)}
.col{padding-left:12px;padding-right:12px;flex:1 0 0%;min-width:260px}

.navbar{
  --nav-bg: rgba(255,252,248,.9);
  --nav-border:#EAE7E1;
  --nav-link:#111827;
  --nav-link-muted:#6B7280;
  --nav-link-active:var(--bs-secondary);
  --nav-hover-bg:#F7F5FF;
  --nav-focus:var(--focus);
  backdrop-filter:saturate(140%) blur(8px);
  background:var(--nav-bg)!important;border-bottom:1px solid var(--nav-border);
  padding-block:.7rem;box-shadow:0 6px 20px rgba(17,24,39,.06)
}
.brand img{display:block}
.navbar-brand{padding:.25rem .5rem;border-radius:18px;background:
  conic-gradient(from 210deg at 60% 40%, rgba(255,107,61,.12), transparent 35%),
  conic-gradient(from 20deg at 40% 60%, rgba(124,92,255,.12), transparent 35%)}
.navbar-brand img{display:block;height:32px;width:auto}
.navbar-brand:focus-visible{outline:3px solid var(--nav-focus);outline-offset:2px}
.navbar .container{display:flex;align-items:center;gap:var(--space-2)}
.navbar-nav{align-items:center;gap:.25rem;margin-left:auto;display:flex}
.navbar .nav-link{
  position:relative;display:block;padding:.55rem .8rem;border-radius:16px;
  font-weight:900;color:var(--nav-link);text-decoration:none;letter-spacing:.3px;
  transition:color .15s ease,background-color .15s ease,transform .12s ease
}
@media(min-width:992px){
  .navbar .nav-link::after{
    content:"";position:absolute;left:12px;right:12px;bottom:6px;height:6px;border-radius:999px;
    background:var(--puzzle-gradient);transform:scaleX(0);transform-origin:left;transition:transform .18s ease;opacity:.9
  }
  .navbar .nav-link:hover::after{transform:scaleX(1)}
}
.navbar .nav-link:hover{background:var(--nav-hover-bg);color:var(--nav-link-active);transform:translateY(-1px)}
.navbar .nav-link:focus-visible{outline:3px solid var(--nav-focus);outline-offset:2px}
.navbar .nav-link.active,.navbar .nav-link[aria-current="page"]{color:var(--nav-link-active)!important;background:var(--nav-hover-bg);box-shadow:inset 0 0 0 1px var(--focus)}
@media(min-width:992px){
  .navbar .nav-link.active::after,.navbar .nav-link[aria-current="page"]::after{transform:scaleX(1)}
}
.navbar .navbar-toggler{
  border-radius:16px;border:1px solid var(--nav-border);padding:.45rem .65rem;background:#fff;
  transition:transform .12s ease,box-shadow .15s ease,border-color .15s ease
}
.navbar .navbar-toggler:focus{box-shadow:0 0 0 .2rem rgba(124,92,255,.18);border-color:var(--focus)}
.navbar .navbar-toggler:hover{transform:translateY(-1px)}
.collapse{display:none}
.collapse.show{display:block}
@media(min-width:992px){
  .navbar .navbar-toggler{display:none}
  .collapse{display:block!important}
}
@media(max-width:991.98px){
  .navbar-collapse{
    background:#fff;border:1px solid var(--nav-border);border-radius:18px;
    box-shadow:0 14px 28px rgba(17,24,39,.12);padding:.5rem;margin-top:.6rem
  }
  .navbar-nav .nav-item{margin:.1rem}
  .navbar-nav .nav-link{padding:.7rem .9rem}
}

.hero{
  background:
    radial-gradient(1200px 420px at 30% -50%,var(--tint-primary) 0,rgba(255,241,232,0) 70%),
    linear-gradient(120deg,var(--tint-primary),#EEF2FF);
  border:1px solid var(--bs-border);border-radius:20px;
  padding:var(--space-6);display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);
  position:relative;overflow:hidden
}
.hero::after{
  content:"";position:absolute;inset:auto -20% -35% -20%;height:260px;background:var(--craft-gradient);pointer-events:none
}
.hero h1{margin:0 0 var(--space-2) 0}
.hero p{margin:0 0 10px 0}
.hero .eyebrow{
  display:inline-block;background:#F7F5FF;color:#4C1D95;border:1px solid #DDD6FE;
  border-radius:999px;font-size:.82rem;padding:4px 12px;font-weight:900;letter-spacing:.3px
}

h1,h2,h3,h4,h5,h6{margin-top:1.4em;margin-bottom:.55em;line-height:1.22;letter-spacing:.2px}
h1{color:var(--h1-color);font-weight:900;font-size:clamp(2rem,2.8vw,2.4rem);margin-top:0}
h2{color:var(--h2-color);font-weight:900;font-size:clamp(1.6rem,2.2vw,1.9rem);padding-bottom:8px;border-bottom:1px solid var(--bs-border)}
h3{color:var(--h3-color);font-weight:800;font-size:1.16rem}
h4{color:var(--h4-color);font-weight:700}
h5{color:var(--h5-color);font-weight:700}
h6{color:var(--h6-color);font-weight:700}
.lead{font-size:1.14rem;color:#374151;margin-bottom:var(--space-3)}
p{margin:0 0 var(--space-3)}
ul,ol{margin:0 0 var(--space-3) var(--space-4);padding:0}
li{margin-bottom:8px}

.card{
  background:var(--bs-card);border:1px solid var(--bs-border);border-radius:22px;
  box-shadow:var(--bs-shadow);margin-bottom:var(--space-5);
  transition:transform .12s ease,box-shadow .18s ease,filter .12s ease;
  position:relative;overflow:hidden
}
.card:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(17,24,39,.09)}
.card::after{
  content:"";position:absolute;inset:0 0 auto 0;height:10px;background:var(--puzzle-gradient);
  mask:radial-gradient(9px 9px at 10px 10px,#000 99%,transparent 100%) repeat-x 0 0/40px 40px;
  opacity:.18
}
.card-body{padding:var(--space-5)}
@media(min-width:1200px){.card>.card-body{max-width:900px;margin:0 auto}}

.badge{
  display:inline-block;background:#F7F5FF;color:#4C1D95;border:1px solid #DDD6FE;
  border-radius:14px;font-size:.82rem;padding:6px 12px;font-weight:900;transform:rotate(-0.6deg)
}
.kwd-pill,.filter-pill{
  display:inline-block;background:#FFF;border-radius:999px;padding:8px 12px;margin:8px 8px 0 0;
  font-size:.92rem;border:1px solid var(--bs-border)
}
.filter-pill.is-active{background:#F7F5FF;border-color:#DDD6FE;color:#4C1D95;font-weight:900}

.btn{
  display:inline-block;cursor:pointer;border:1px solid transparent;border-radius:16px;
  padding:12px 18px;font-weight:900;letter-spacing:.2px;position:relative;isolation:isolate
}
.btn-primary{background:var(--bs-primary);color:#fff}
.btn-primary:hover{background:var(--bs-primary-600)}
.btn-primary:active{background:var(--bs-primary-700)}
.btn-outline{background:transparent;border-color:var(--bs-border);color:var(--bs-dark)}
.btn-outline:hover{border-color:var(--bs-secondary);color:var(--bs-secondary);background:#F7F5FF}
.btn-boost,.btn-love{background:var(--puzzle-gradient);color:#fff;border:none}
.btn-boost:hover,.btn-love:hover{filter:brightness(.96)}
.btn-ghost{background:transparent;border:1px dashed var(--bs-border);color:var(--bs-dark)}
.btn-ghost:hover{border-color:var(--bs-secondary);background:#F7F5FF;color:var(--bs-secondary)}
.btn-fidget{background:#fff;border:1px solid var(--bs-border);box-shadow:0 8px 18px rgba(17,24,39,.08)}
.btn-fidget:active{animation:fidget-press .18s ease both}

.breadcrumb{font-size:.96rem;color:#8a98a6;margin-bottom:var(--space-3)}
.breadcrumb a{color:inherit}
@media(max-width:576px){
  .breadcrumb{font-size:0;margin-bottom:var(--space-2);color:#9aa7b3}
  .breadcrumb a,.breadcrumb span{display:none}
  .breadcrumb a:first-of-type,.breadcrumb span:last-of-type{display:inline;font-size:.92rem;color:#7d8a97}
}

.toc{background:#fff;border:1px solid var(--bs-border);border-radius:18px;padding:0}
.toc .card-body{padding:var(--space-4)}
.toc h2{margin:0 0 var(--space-2) 0;font-size:1.05rem;border-bottom:1px solid var(--bs-border);padding-bottom:6px}
.toc .list-group{display:grid;grid-template-columns:1fr;gap:12px;padding-left:0;margin:0}
.toc .list-group .list-group-item{
  margin:0;border:1px solid var(--bs-border);border-radius:18px;padding:14px 16px;background:#fff;
  box-shadow:0 1px 2px rgba(17,24,39,0.04);
  transition:transform .08s ease,box-shadow .12s ease,border-color .12s ease
}
.toc .list-group .list-group-item:hover{transform:translateY(-1px);border-color:#DDD6FE;box-shadow:0 4px 12px rgba(17,24,39,0.08)}
.toc .list-group .list-group-item>a{
  display:block;width:100%;color:var(--h2-color);font-weight:900;line-height:1.35;word-break:break-word;hyphens:auto;text-decoration:none
}
.toc .list-group .list-group-item>a:focus,.toc .list-group .list-group-item>a:hover{text-decoration:none;color:var(--h1-color)}
@media(min-width:480px){.toc .list-group{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.toc .list-group{grid-template-columns:repeat(3,1fr);gap:14px}}

.product-cards{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:600px){.product-cards{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.product-cards{grid-template-columns:repeat(3,1fr)}}
.product-cards .card{border:1px solid var(--bs-border);overflow:hidden;position:relative}
.product-cards h3{margin-top:6px}
.product-thumb{border-radius:16px;overflow:hidden;background:#FFF}
.product-thumb img{display:block;width:100%;height:auto;transition:transform .25s ease}
.product-cards .card:hover .product-thumb img{transform:scale(1.04) rotate(.2deg)}
.ribbon{
  position:absolute;top:14px;left:-8px;background:var(--puzzle-gradient);
  color:#fff;padding:6px 14px;border-top-right-radius:14px;border-bottom-right-radius:14px;font-weight:900;letter-spacing:.3px;
  box-shadow:0 8px 18px rgba(17,24,39,.18)
}
.price{display:flex;align-items:baseline;gap:8px;margin-top:6px}
.price .current{font-weight:900;font-size:1.2rem;color:var(--price)}
.price .compare{color:var(--price-compare);text-decoration:line-through}
.price .tag{display:inline-block;background:#F7F5FF;color:#7C5CFF;border:1px solid #DDD6FE;border-radius:999px;padding:2px 8px;font-weight:900;font-size:.8rem}

.rating{display:inline-flex;gap:2px;align-items:center}
.rating .star{
  --sz:18px;width:var(--sz);height:var(--sz);display:inline-block;
  mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" fill="%23FFF" viewBox="0 0 24 24"><path d="M12 .587l3.668 7.431 8.2 1.192-5.934 5.787 1.402 8.167L12 18.896 4.664 23.164l1.402-8.167L.132 9.21l8.2-1.192z"/></svg>') no-repeat center/contain;
  background:var(--star)
}
.rating .star.off{background:var(--star-off)}
.rating small{margin-left:6px;color:var(--bs-muted)}

.pros-cons{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:700px){.pros-cons{grid-template-columns:1fr 1fr}}
.pros,.cons{border:1px solid var(--bs-border);border-radius:18px;padding:14px 16px;background:#fff}
.pros h4,.cons h4{margin:0 0 8px;font-size:1rem}
.pros ul,.cons ul{margin:0;padding-left:18px}
.pros li::marker{color:#22C55E}
.cons li::marker{color:#EF4444}

.disclaimer{background:#F7F5FF;border:1px solid #DDD6FE;border-radius:14px;padding:12px 14px;color:#4C1D95;font-size:.92rem}

.age-badge{display:inline-flex;align-items:center;gap:6px;background:#111827;color:#fff;border-radius:999px;padding:4px 10px;font-weight:900;font-size:.82rem}
.safety-banner{display:flex;gap:12px;align-items:flex-start;background:#FFF;border:1px solid var(--bs-border);border-radius:14px;padding:12px 14px}
.safety-banner .icon{font-size:20px;line-height:1}

.footer{
  margin-top:var(--space-7);padding:var(--space-6) 0;border-top:1px solid var(--bs-border);
  color:var(--bs-muted);background:linear-gradient(180deg,var(--tint-primary),var(--tint-secondary))
}
.e-motion-gradient,.sensual-gradient,.smile-gradient{background:linear-gradient(135deg,var(--tint-primary) 0%,var(--tint-secondary) 100%)}
.soft-border{border:1px solid var(--bs-border)}
.shadow-soft{box-shadow:var(--bs-shadow)}
.section{margin:40px 0}
.max-w-prose{max-width:72ch}
.text-volt{color:var(--bs-secondary)}
.bg-mint-tint{background:#F7F5FF}
.bg-cobalt-tint{background:var(--tint-primary)}

figure{margin:0 0 var(--space-5)}
figcaption{margin-top:6px;color:#6B7280;font-size:.92rem}

@media(max-width:576px){
  .card-body{padding:calc(var(--space-4) + 2px)}
  .lead{margin-bottom:var(--space-3)}
  h2{margin-top:1.2em}
}

@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}

.footer{position:relative;overflow:hidden}
.footer::before{
  content:"";position:absolute;inset:-60% -20% auto -20%;height:240px;
  background:radial-gradient(600px 160px at 50% 100%,rgba(124,92,255,.14),transparent 70%),
             radial-gradient(400px 120px at 10% 90%,rgba(14,165,164,.12),transparent 70%);
  pointer-events:none
}
.footer .container{position:relative;z-index:1}
.footer .row{row-gap:1.25rem}
.footer .d-inline-flex.text-decoration-none{padding:.35rem .6rem;border-radius:16px;transition:background-color .15s ease,transform .12s ease}
.footer .d-inline-flex.text-decoration-none:hover{background:#F7F5FF;transform:translateY(-1px)}
.footer p{margin-bottom:.75rem}
.footer .text-body{color:#111827!important;font-weight:900;letter-spacing:.2px}
.footer .text-body-secondary{color:#6B7280!important}
.footer a{text-decoration:none}
.footer a.link-secondary{
  color:#6B7280!important;transition:color .15s ease,background-color .15s ease,transform .12s ease;
  border-radius:12px;padding:.25rem .4rem
}
.footer a.link-secondary:hover{color:var(--bs-secondary)!important;background:#F7F5FF;transform:translateY(-1px)}
.footer a:focus-visible{outline:3px solid var(--focus);outline-offset:2px}
.footer .border-top{border-top:1px solid var(--bs-border)!important}
.footer a[aria-label="Till toppen"]{
  display:inline-flex;align-items:center;gap:.15rem;background:#fff;border:1px solid var(--bs-border);
  padding:.4rem .7rem;border-radius:999px;font-weight:900;box-shadow:0 6px 18px rgba(17,24,39,.06)
}
.footer a[aria-label="Till toppen"]:hover{background:#F7F5FF;border-color:#DDD6FE;color:var(--bs-secondary)!important}
.footer a[aria-label="Till toppen"] i{font-size:1.1rem;line-height:1}

.table{
  --tbl-border:#EAE7E1;--tbl-head-bg:linear-gradient(180deg,#F7F5FF,#FFF1E8);
  --tbl-head-text:#0F172A;--tbl-row-hover:#FFF3E9;--tbl-stripe:#FDFBFF;--tbl-shadow:0 8px 26px rgba(17,24,39,.08);--tbl-focus:var(--focus);
  width:100%;background:#fff;border:1px solid var(--tbl-border)!important;border-radius:18px;overflow:hidden;box-shadow:var(--tbl-shadow);margin-bottom:1.25rem
}
.table th,.table td{padding:.9rem 1rem;vertical-align:middle;border-color:var(--tbl-border)!important}
.table thead th{
  background:var(--tbl-head-bg);color:var(--tbl-head-text);font-weight:900;letter-spacing:.2px;
  border-bottom:1px solid var(--tbl-border)!important;position:sticky;top:0;z-index:2
}
.table tbody td:first-child{font-weight:900;color:#0B1220}
.table.table-striped>tbody>tr:nth-of-type(odd)>*{--bs-table-accent-bg:var(--tbl-stripe);color:inherit}
.table tbody tr:hover>*{background:var(--tbl-row-hover)!important}
.table td:nth-last-child(-n+2){line-height:1.6}
.table td:nth-child(2),.table td:nth-child(3){white-space:nowrap}
.table i[class^="bi-"],.table i[class*=" bi-"]{margin-right:.35rem}
.table caption{caption-side:top;padding:.75rem 1rem 0;color:#6B7280;font-size:.95rem}
.table :where(th,td):focus-within{outline:3px solid var(--tbl-focus);outline-offset:-3px}
@media(max-width:640px){
  .table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .table thead th{top:0}
  .table::-webkit-scrollbar{height:10px}
  .table::-webkit-scrollbar-track{background:#F3F4F6;border-radius:999px}
  .table::-webkit-scrollbar-thumb{background:#E5E7EB;border-radius:999px;border:2px solid #F3F4F6}
}

:root,html,body,[data-bs-theme],[data-bs-theme="dark"]{
  color-scheme:light!important;
  --bs-body-bg:#FFFFFF!important;
  --bs-body-color:#212529!important;
  --bs-emphasis-color:#000!important;
  --bs-border-color:#dee2e6!important;
  --bs-link-color:var(--link)!important;
  --bs-link-hover-color:var(--link-hover)!important;
}
html,body,[data-bs-theme]{background:var(--bs-bg)!important;color:var(--bs-body)!important}

#produkter .card > a{
  display:flex;
  align-items:center;
  justify-content:center;
  height:300px;
  background:#fff;
}

#produkter .card > a > img.card-img-top{
  max-height:100%;
  max-width:100%;
  width:auto;
  height:auto;
  object-fit:contain;
  object-position:center;
  display:block;
}

@media (max-width:480px){
  #produkter .card > a{height:220px}
}

/* Pyssel, pussel & fidget extras (no comments in output, kept for structure by empty selectors) */
.puzzle-edge{
  -webkit-mask:
    radial-gradient(10px 10px at 20px -2px,#000 99%,transparent 100%) 0 0/40px 40px repeat-x,
    radial-gradient(10px 10px at 20px calc(100% + 2px),#000 99%,transparent 100%) 0 100%/40px 40px repeat-x,
    linear-gradient(#000 0 0) content-box;
  mask:
    radial-gradient(10px 10px at 20px -2px,#000 99%,transparent 100%) 0 0/40px 40px repeat-x,
    radial-gradient(10px 10px at 20px calc(100% + 2px),#000 99%,transparent 100%) 0 100%/40px 40px repeat-x,
    linear-gradient(#000 0 0) content-box;
  background:#fff;border:1px solid var(--bs-border);border-radius:18px;padding:var(--space-5)
}
.puzzle-grid{
  background:
    radial-gradient(8px 8px at 14px 14px,rgba(124,92,255,.08) 30%,transparent 32%) 0 0/40px 40px,
    radial-gradient(8px 8px at 26px 26px,rgba(255,107,61,.08) 30%,transparent 32%) 0 0/40px 40px,
    #fff
}
.craft-dots{
  --dot-c: rgba(17,24,39,.08);
  background:var(--dots);background-size:12px 12px;background-color:#fff;color:#111827
}
.sticker{
  background:#fff;border:2px dashed #DDD6FE;border-radius:16px;box-shadow:0 8px 18px rgba(17,24,39,.06);
  transform:rotate(-.4deg);padding:10px 14px;font-weight:900
}
.fidget{
  display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:8px 12px;
  background:#FFF;border:1px solid var(--bs-border);box-shadow:0 6px 18px rgba(17,24,39,.06)
}
.fidget:hover .fidget-dot{animation:fidget-pop .5s ease forwards}
.fidget-dot{width:8px;height:8px;border-radius:999px;background:var(--bs-secondary);display:inline-block}

@keyframes fidget-pop{
  0%{transform:scale(1)}
  35%{transform:scale(1.6)}
  100%{transform:scale(1)}
}
@keyframes fidget-press{
  0%{transform:translateY(0) scale(1)}
  50%{transform:translateY(1px) scale(.98)}
  100%{transform:translateY(0) scale(1)}
}

.card-pulse{
  position:relative
}
.card-pulse::before{
  content:"";position:absolute;inset:8px;pointer-events:none;border-radius:18px;
  background:conic-gradient(from 0deg, rgba(124,92,255,.08), rgba(255,107,61,.08), rgba(14,165,164,.08), rgba(124,92,255,.08));
  filter:blur(18px);opacity:.7;z-index:-1
}

.tab-fidget .nav-link{
  border-radius:16px;border:1px solid var(--bs-border);margin-right:8px;background:#fff
}
.tab-fidget .nav-link.active{
  color:#4C1D95;background:#F7F5FF;border-color:#DDD6FE;box-shadow:inset 0 0 0 2px #E9E5FF
}

.form-craft input,.form-craft select,.form-craft textarea{
  border-radius:16px;border:1px solid var(--bs-border);padding:12px 14px;background:#fff
}
.form-craft input:focus,.form-craft select:focus,.form-craft textarea:focus{
  outline:3px solid var(--focus);outline-offset:1px;background:#FFFBF2
}

.alert-craft{
  background:#FFF; border:2px dashed #FFD8BF;color:#7A2E0E;border-radius:18px;padding:14px 16px
}

.progress-puzzle{
  height:14px;background:#FFF;border:1px solid var(--bs-border);border-radius:999px;position:relative;overflow:hidden
}
.progress-puzzle .bar{
  position:absolute;inset:0 auto 0 0;width:40%;background:var(--puzzle-gradient)
}

.card-confetti{
  position:relative;overflow:hidden
}
.card-confetti::after{
  content:"";position:absolute;inset:-20% -20% auto -20%;height:120px;
  background:
    radial-gradient(6px 6px at 20% 30%, rgba(255,107,61,.25) 40%, transparent 41%) 0 0/70px 70px,
    radial-gradient(6px 6px at 70% 60%, rgba(124,92,255,.25) 40%, transparent 41%) 0 0/60px 60px,
    radial-gradient(6px 6px at 40% 10%, rgba(14,165,164,.25) 40%, transparent 41%) 0 0/80px 80px
}

.wiggle:hover{animation:wiggle .35s ease-in-out}
@keyframes wiggle{
  0%{transform:rotate(0)}
  25%{transform:rotate(-1.2deg)}
  50%{transform:rotate(1.2deg)}
  100%{transform:rotate(0)}
}
