:root{
  --bg:#17100c;
  --bg-2:#1f1510;
  --bg-3:#2a1c15;
  --cacao:#3b2418;
  --cacao-2:#4a2d1e;
  --gold:#c9a36a;
  --gold-2:#e6c892;
  --cream:#f4ead8;
  --muted:#b8a997;
  --line:rgba(201,163,106,.18);
  --ok:#7fb98b;
  --err:#e08a7a;
  --radius:14px;
  --shadow:0 18px 48px rgba(0,0,0,.45);
  --maxw:1180px;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font);
  background:
    radial-gradient(1200px 600px at 80% -10%,rgba(201,163,106,.10),transparent 60%),
    radial-gradient(900px 500px at -10% 20%,rgba(230,200,146,.06),transparent 60%),
    linear-gradient(180deg,var(--bg),var(--bg-2) 60%,var(--bg));
  color:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--gold-2);text-decoration:none}
a:hover{color:var(--cream)}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{
  outline:2px solid var(--gold-2);outline-offset:3px;border-radius:6px;
}
img{max-width:100%;display:block}
h1,h2,h3{font-weight:600;letter-spacing:.2px;color:#fff;margin:0 0 .6em}
h1{font-size:clamp(2rem,4.4vw,3.2rem);line-height:1.15}
h2{font-size:clamp(1.5rem,2.6vw,2.1rem);line-height:1.2;margin-top:0}
h3{font-size:1.15rem}
p{margin:.4em 0 1em;color:var(--cream)}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.small{font-size:.88rem;color:var(--muted)}

/* Header */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  backdrop-filter:saturate(150%) blur(14px);
  -webkit-backdrop-filter:saturate(150%) blur(14px);
  background:linear-gradient(180deg,rgba(23,16,12,.92),rgba(23,16,12,.72));
  border-bottom:1px solid rgba(201,163,106,.18);
  box-shadow:0 6px 24px rgba(0,0,0,.25);
}
body{padding-top:78px}
@media (max-width:820px){ body{padding-top:68px} }

.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 6px;gap:22px;min-height:50px;
}

/* Brand / logo — Kakao Atelier seal */
.brand{
  display:flex;align-items:center;gap:14px;font-weight:700;color:#fff;
  flex:0 0 auto;transition:transform .25s ease;
  position:relative;
}
.brand:hover{transform:translateY(-1px)}
.brand-mark{
  width:46px;height:46px;border-radius:50%;flex:0 0 auto;
  position:relative;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'><defs><radialGradient id='rim' cx='38%25' cy='32%25' r='85%25'><stop offset='0%25' stop-color='%23fff3d6'/><stop offset='38%25' stop-color='%23e6c892'/><stop offset='78%25' stop-color='%23a07940'/><stop offset='100%25' stop-color='%235a3820'/></radialGradient><radialGradient id='core' cx='38%25' cy='30%25' r='85%25'><stop offset='0%25' stop-color='%234a2d1e'/><stop offset='55%25' stop-color='%231f120a'/><stop offset='100%25' stop-color='%230a0503'/></radialGradient><linearGradient id='gold' x1='0' y1='1' x2='1' y2='0'><stop offset='0' stop-color='%238a6a3c'/><stop offset='50%25' stop-color='%23f4dca6'/><stop offset='100%25' stop-color='%23c9a36a'/></linearGradient></defs><circle cx='32' cy='32' r='31' fill='url(%23rim)'/><circle cx='32' cy='32' r='31' fill='none' stroke='%232a1610' stroke-width='.8' opacity='.55'/><circle cx='32' cy='32' r='27.5' fill='none' stroke='%23f4dca6' stroke-width='.4' opacity='.5' stroke-dasharray='1.2 1.8'/><circle cx='32' cy='32' r='25' fill='url(%23core)' stroke='url(%23gold)' stroke-width='.9'/><ellipse cx='32' cy='32' rx='9' ry='16' fill='url(%23gold)'/><ellipse cx='32' cy='32' rx='9' ry='16' fill='none' stroke='%235a3820' stroke-width='.6'/><path d='M32 17 L32 47' stroke='%235a3820' stroke-width='.7' opacity='.8'/><path d='M27.5 19 Q28.5 32 27.5 45' stroke='%233b2418' stroke-width='.5' fill='none' opacity='.7'/><path d='M36.5 19 Q35.5 32 36.5 45' stroke='%233b2418' stroke-width='.5' fill='none' opacity='.7'/><path d='M32 17 Q29 13 32.5 10.5' stroke='%235a3820' stroke-width='1.3' fill='none' stroke-linecap='round'/><ellipse cx='28.5' cy='24' rx='2.8' ry='6.5' fill='white' opacity='.28'/><circle cx='48' cy='18' r='1.3' fill='%23fff3d6'/><circle cx='14' cy='46' r='.9' fill='%23fff3d6' opacity='.75'/><circle cx='50' cy='44' r='.7' fill='%23fff3d6' opacity='.6'/></svg>") center/contain no-repeat;
  box-shadow:
    0 0 0 1px rgba(201,163,106,.35),
    0 8px 22px rgba(0,0,0,.55),
    0 0 18px rgba(201,163,106,.18);
  transition:transform .5s cubic-bezier(.2,.8,.2,1),box-shadow .4s ease,filter .4s ease;
}
.brand-mark::after{
  content:"";position:absolute;inset:-4px;border-radius:50%;pointer-events:none;
  background:conic-gradient(from 0deg,transparent 0 55%,rgba(244,220,166,.35) 65%,transparent 75%);
  opacity:0;transition:opacity .4s ease;
  -webkit-mask:radial-gradient(circle,transparent 58%,#000 60%);
  mask:radial-gradient(circle,transparent 58%,#000 60%);
}
.brand:hover .brand-mark{
  transform:rotate(-10deg) scale(1.05);
  box-shadow:
    0 0 0 1px rgba(244,220,166,.6),
    0 12px 30px rgba(0,0,0,.6),
    0 0 26px rgba(244,220,166,.4);
  filter:brightness(1.08);
}
.brand:hover .brand-mark::after{opacity:1;animation:ka-shimmer 2.2s linear infinite}

.brand-name{
  font-size:1.1rem;letter-spacing:.6px;line-height:1.15;
  background:linear-gradient(180deg,#ffffff 0%,#f4dca6 55%,#d2a96d 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  font-weight:700;
  filter:drop-shadow(0 2px 6px rgba(0,0,0,.4));
}
.brand-name span{
  display:block;margin-top:3px;
  -webkit-text-fill-color:var(--gold-2);color:var(--gold-2);
  font-weight:400;font-size:.68rem;
  letter-spacing:2px;text-transform:uppercase;
  background:none;
}

/* Desktop nav list */
.nav ul{
  display:flex;gap:6px;list-style:none;margin:0;padding:0;
  align-items:center;flex-wrap:wrap;
}
.nav ul a{
  color:var(--cream);font-size:.94rem;font-weight:500;
  padding:9px 14px;border-radius:999px;position:relative;
  transition:color .2s ease,background .2s ease;
  white-space:nowrap;display:inline-block;
}
.nav ul a:hover{color:var(--gold-2);background:rgba(201,163,106,.08)}
.nav ul a[aria-current="page"],.nav ul a.active{
  color:var(--gold-2);background:rgba(201,163,106,.12);
}
.nav ul a[aria-current="page"]::after,.nav ul a.active::after{
  content:"";position:absolute;left:50%;bottom:3px;width:18px;height:2px;
  transform:translateX(-50%);
  background:linear-gradient(90deg,var(--gold-2),var(--gold));border-radius:2px;
}

/* Hamburger */
.nav-toggle{
  display:none;position:relative;width:44px;height:42px;
  margin-left:auto;flex:0 0 auto;
  background:rgba(201,163,106,.06);
  border:1px solid rgba(201,163,106,.28);border-radius:10px;cursor:pointer;
  transition:background .2s ease,border-color .2s ease;
}
.nav-toggle:hover{background:rgba(201,163,106,.12);border-color:rgba(201,163,106,.5)}
.nav-toggle span{
  position:absolute;left:11px;right:11px;height:2px;background:var(--gold-2);
  border-radius:2px;
  transition:transform .25s ease,top .25s ease,opacity .15s ease;
}
.nav-toggle span:nth-child(1){top:14px}
.nav-toggle span:nth-child(2){top:20px}
.nav-toggle span:nth-child(3){top:26px}
.nav-toggle.is-open span:nth-child(1){top:20px;transform:rotate(45deg)}
.nav-toggle.is-open span:nth-child(2){opacity:0}
.nav-toggle.is-open span:nth-child(3){top:20px;transform:rotate(-45deg)}

/* Tablet — tighter gaps */
@media (max-width:980px){
  .nav{gap:14px}
  .nav ul{gap:2px}
  .nav ul a{padding:8px 11px;font-size:.9rem}
}

/* Mobile */
@media (max-width:820px){
  .container{padding:0 18px}
  .nav{padding:11px 20px;gap:12px;position:relative}
  .brand{min-width:0;flex:1 1 auto;overflow:hidden}
  .brand-name{font-size:.98rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .brand-name span{font-size:.62rem;letter-spacing:1.6px}
  .brand-mark{width:40px;height:40px;border-radius:50%}
  .nav-toggle{display:inline-block}

  .nav > nav{
    position:absolute;top:calc(100% + 10px);left:0;right:0;
    display:grid;grid-template-rows:0fr;
    transition:grid-template-rows .3s ease;
    pointer-events:none;
  }
  .nav > nav:has(ul.open){grid-template-rows:1fr;pointer-events:auto}
  .nav ul{
    flex-direction:column;align-items:stretch;gap:4px;
    min-height:0;overflow:hidden;
    background:linear-gradient(180deg,rgba(32,22,16,.98),rgba(23,16,12,.98));
    border:1px solid rgba(201,163,106,.22);border-radius:14px;
    box-shadow:0 18px 40px rgba(0,0,0,.45);
    padding:0 12px;
    opacity:0;transform:translateY(-6px);
    transition:opacity .28s ease,transform .28s ease,padding .3s ease;
  }
  .nav ul.open{
    opacity:1;transform:translateY(0);
    padding:12px;
  }
  .nav ul a{
    display:block;padding:12px 16px;border-radius:10px;font-size:.98rem;
    color:var(--cream);font-weight:500;
    transition:color .2s ease,background .2s ease;
  }
  .nav ul a:hover,.nav ul a[aria-current="page"],.nav ul a.active{
    color:var(--gold-2);background:rgba(201,163,106,.1);
  }
  .nav ul a[aria-current="page"]::after,.nav ul a.active::after{display:none}
}
@media (max-width:520px){
  .brand-name{font-size:.9rem}
  .brand-name br{display:none}
  .brand-name span{margin-left:6px}
}
@media (max-width:480px){
  .nav{padding:10px 14px;gap:10px}
  .brand{gap:10px}
  .brand-name{font-size:.85rem}
  .brand-mark{width:34px;height:34px}
}
@media (max-width:380px){
  .brand-name span{display:none}
}

/* Buttons */
.btn{
  display:inline-block;padding:13px 22px;border-radius:10px;font-weight:600;letter-spacing:.3px;
  border:1px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,background .2s ease;
}
.btn-primary{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#241812;box-shadow:0 10px 24px rgba(201,163,106,.22)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 14px 30px rgba(201,163,106,.3)}
.btn-ghost{background:transparent;color:var(--cream);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--gold-2);color:var(--gold-2)}

/* Hero */
.hero{padding:80px 0 70px;position:relative;overflow:hidden}
.hero::before{
  content:"";position:absolute;inset:-1px;pointer-events:none;
  background:
    radial-gradient(800px 400px at 75% 30%,rgba(230,200,146,.14),transparent 60%),
    radial-gradient(500px 260px at 20% 80%,rgba(201,163,106,.10),transparent 60%);
}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;position:relative}
@media (max-width:900px){.hero-grid{grid-template-columns:1fr}}
.hero p.lead{font-size:1.1rem;color:var(--cream);max-width:58ch}
.hero .kicker{display:inline-block;padding:6px 12px;border:1px solid var(--line);border-radius:999px;color:var(--gold-2);font-size:.82rem;letter-spacing:1.2px;text-transform:uppercase;margin-bottom:16px}
.hero-cta{display:flex;gap:14px;margin-top:26px;flex-wrap:wrap}

/* Hero visual */
.pack{
  position:relative;aspect-ratio:1/1;max-width:460px;margin-left:auto;
  border-radius:22px;
  background:
    linear-gradient(145deg,#4a2d1e,#2a1c15 60%,#17100c),
    #2a1c15;
  border:1px solid var(--line);
  box-shadow:var(--shadow),inset 0 0 0 1px rgba(255,255,255,.04);
  overflow:hidden;
}
.pack::before{
  content:"";position:absolute;inset:0;
  background:
    repeating-linear-gradient(45deg,rgba(230,200,146,.05) 0 10px,transparent 10px 22px);
  mix-blend-mode:overlay;
}
.pack-ribbon{
  position:absolute;left:0;right:0;top:52%;height:32px;
  background:linear-gradient(180deg,var(--gold-2),var(--gold));
  box-shadow:0 8px 18px rgba(0,0,0,.35);
}
.pack-seal{
  position:absolute;left:50%;top:52%;transform:translate(-50%,-50%);
  width:84px;height:84px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#e6c892,#8a6a3c);
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.25),0 10px 26px rgba(0,0,0,.5);
  display:grid;place-items:center;color:#241812;font-weight:700;letter-spacing:1px;font-size:.75rem;
}

/* Sections */
section{padding:64px 0;border-top:1px solid var(--line)}
.section-intro{max-width:72ch;color:var(--muted)}

/* Cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:26px}
@media (max-width:900px){.cards{grid-template-columns:1fr}}
.card{
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,0)) ,var(--bg-3);
  border:1px solid var(--line);border-radius:var(--radius);padding:22px;transition:transform .2s ease,border-color .2s ease;
}
.card:hover{transform:translateY(-3px);border-color:rgba(201,163,106,.4)}
.card h3{color:var(--gold-2)}
.card ul{padding-left:18px;margin:10px 0 0;color:var(--cream)}
.card li{margin:4px 0}

/* Process */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:24px;counter-reset:step}
@media (max-width:900px){.steps{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.steps{grid-template-columns:1fr}}
.step{
  position:relative;padding:20px 18px 18px;border:1px solid var(--line);border-radius:12px;background:var(--bg-3);
}
.step::before{
  counter-increment:step;content:counter(step);
  position:absolute;top:-14px;left:16px;
  width:30px;height:30px;border-radius:50%;
  background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#241812;font-weight:700;
  display:grid;place-items:center;box-shadow:0 6px 14px rgba(0,0,0,.35);
}
.step h3{font-size:1rem;margin-top:6px}

/* Price planner */
.planner{
  display:grid;grid-template-columns:1.05fr .95fr;gap:24px;margin-top:26px;
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,0)),var(--bg-3);
  border:1px solid var(--line);border-radius:var(--radius);padding:26px;
}
@media (max-width:900px){.planner{grid-template-columns:1fr}}
.planner label{display:block;font-size:.9rem;color:var(--muted);margin-bottom:6px}
.planner .row{margin-bottom:18px}
.seg{display:inline-flex;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.seg button{padding:10px 16px;background:transparent;color:var(--cream);border:0;cursor:pointer;font:inherit}
.seg button[aria-pressed="true"]{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#241812}
.planner input[type="range"]{width:100%}
.planner .toggle{display:flex;align-items:center;gap:10px}
.planner .estimate{
  background:var(--bg-2);border:1px dashed var(--line);border-radius:12px;padding:18px;
}
.estimate .val{font-size:1.6rem;color:#fff;font-weight:700;letter-spacing:.3px}
.estimate .hint{color:var(--muted);font-size:.85rem;margin-top:6px}
.disclaimer{margin-top:14px;padding:12px 14px;border-left:3px solid var(--gold);background:rgba(201,163,106,.08);color:var(--cream);border-radius:6px;font-size:.9rem}

/* Price table */
.price-table{width:100%;border-collapse:collapse;margin-top:18px;background:var(--bg-3);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.price-table th,.price-table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--line)}
.price-table th{background:var(--bg-2);color:var(--gold-2);font-weight:600;font-size:.92rem;letter-spacing:.3px}
.price-table tr:last-child td{border-bottom:0}

/* FAQ */
.faq{margin-top:20px}
.faq details{
  background:var(--bg-3);border:1px solid var(--line);border-radius:12px;padding:16px 18px;margin-bottom:12px;
}
.faq details[open]{border-color:rgba(201,163,106,.4)}
.faq summary{cursor:pointer;font-weight:600;color:#fff;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--gold-2);font-size:1.25rem;line-height:1}
.faq details[open] summary::after{content:"–"}

/* Form */
.form{
  background:var(--bg-3);border:1px solid var(--line);border-radius:var(--radius);padding:24px;
}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:700px){.form .row{grid-template-columns:1fr}}
.form label{display:block;font-size:.9rem;color:var(--muted);margin:12px 0 6px}
.form input,.form textarea{
  width:100%;padding:12px 14px;background:var(--bg-2);color:var(--cream);
  border:1px solid var(--line);border-radius:10px;font:inherit;
}
.form textarea{min-height:140px;resize:vertical}
.form .hp{position:absolute;left:-9999px;top:-9999px}
.form .consent{display:flex;gap:10px;align-items:flex-start;margin:14px 0}
.form .consent input{width:auto;margin-top:4px}
.form .actions{margin-top:14px}
.form-msg{margin-top:14px;padding:12px 14px;border-radius:10px;display:none}
.form-msg.ok{display:block;background:rgba(127,185,139,.12);border:1px solid rgba(127,185,139,.4);color:#cdeacf}
.form-msg.err{display:block;background:rgba(224,138,122,.12);border:1px solid rgba(224,138,122,.4);color:#f2c9bf}

/* Info grid */
.info{display:grid;grid-template-columns:1fr 1fr;gap:26px}
@media (max-width:800px){.info{grid-template-columns:1fr}}
.info .block{background:var(--bg-3);border:1px solid var(--line);border-radius:var(--radius);padding:22px}

/* Footer */
footer.site-footer{
  margin-top:40px;border-top:1px solid var(--line);padding:40px 0 24px;background:linear-gradient(180deg,var(--bg-2),var(--bg))
}
.foot-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:30px}
@media (max-width:800px){.foot-grid{grid-template-columns:1fr}}
.foot-grid h4{color:var(--gold-2);margin:0 0 10px;font-size:.95rem;letter-spacing:.4px;text-transform:uppercase}
.foot-grid ul{list-style:none;padding:0;margin:0}
.foot-grid li{margin:6px 0}
.legal{margin-top:24px;padding-top:16px;border-top:1px solid var(--line);color:var(--muted);font-size:.85rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* Cookie banner */
.cc{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:100;
  background:#140d09;border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow);padding:18px 20px;display:none;
}
.cc.show{display:block}
.cc-row{display:flex;gap:18px;align-items:center;flex-wrap:wrap;justify-content:space-between}
.cc p{margin:0;color:var(--cream);max-width:70ch}
.cc-actions{display:flex;gap:10px;flex-wrap:wrap}
.cc .btn{padding:10px 16px;font-size:.92rem}
.cc-panel{display:none;margin-top:14px;border-top:1px solid var(--line);padding-top:14px}
.cc-panel.show{display:block}
.cc-panel label{display:flex;align-items:center;gap:10px;margin:8px 0;color:var(--cream)}
.cc-panel .grp{margin:6px 0}
.cc-panel small{color:var(--muted)}

/* Motion */
@media (prefers-reduced-motion:reduce){
  *{transition:none!important;animation:none!important}
}

/* Utilities */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media (max-width:800px){.grid-2{grid-template-columns:1fr}}
.badge{display:inline-block;padding:4px 10px;border:1px solid var(--line);border-radius:999px;font-size:.78rem;color:var(--gold-2);margin-right:6px}
.note{color:var(--muted);font-size:.9rem}
hr.sep{border:0;border-top:1px solid var(--line);margin:24px 0}

/* Inline images (not full width) */
.media-row{display:grid;grid-template-columns:1.2fr .8fr;gap:28px;align-items:center;margin-top:22px}
.media-row.alt{grid-template-columns:.8fr 1.2fr}
.media-row.alt .media-text{order:2}
.media-row.alt .media-img{order:1}
@media (max-width:780px){
  .media-row,.media-row.alt{grid-template-columns:1fr}
  .media-row.alt .media-text{order:1}
  .media-row.alt .media-img{order:2}
}
.media-img{
  border-radius:14px;overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow);background:var(--bg-3);
  max-width:420px;width:100%;justify-self:center;
  aspect-ratio:4/3;
}
.media-img img{width:100%;height:100%;object-fit:cover;display:block}

/* Standalone form block */
.form-standalone{
  margin-top:40px;padding:30px;
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,0)),var(--bg-3);
  border:1px solid var(--line);border-left:4px solid var(--gold);
  border-radius:var(--radius);box-shadow:var(--shadow);
}
.form-standalone h2{margin-top:0}

/* =====================================================
   ADVANCED THEMED EFFECTS — Kakao Atelier
   ===================================================== */

/* Keyframes */
@keyframes ka-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes ka-glow{0%,100%{box-shadow:0 10px 24px rgba(201,163,106,.22),0 0 0 0 rgba(201,163,106,.35)}50%{box-shadow:0 14px 32px rgba(201,163,106,.32),0 0 0 10px rgba(201,163,106,0)}}
@keyframes ka-shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes ka-ribbon{0%,15%{transform:translateX(-120%) skewX(-18deg)}65%,100%{transform:translateX(260%) skewX(-18deg)}}
@keyframes ka-shine{0%{transform:translateX(-140%) skewX(-22deg)}100%{transform:translateX(280%) skewX(-22deg)}}
@keyframes ka-melt{0%{transform:translateY(0) scaleY(1)}40%{transform:translateY(8%) scaleY(1.04)}100%{transform:translateY(112%) scaleY(1.08)}}
@keyframes ka-seal{0%{transform:translate(-50%,-50%) scale(.25) rotate(-22deg);opacity:0}35%{opacity:1}62%{transform:translate(-50%,-50%) scale(1) rotate(0);opacity:1}100%{transform:translate(-50%,-50%) scale(4) rotate(10deg);opacity:0}}
@keyframes ka-drop{0%{transform:translateY(-22px) scaleY(.82);opacity:0;filter:blur(6px)}65%{transform:translateY(3px) scaleY(1.03);opacity:1;filter:blur(0)}100%{transform:translateY(0) scaleY(1)}}
@keyframes ka-bean{0%{transform:translateY(-50%) rotate(-55deg) scale(.4);opacity:0}100%{transform:translateY(-50%) rotate(0) scale(1);opacity:1}}

/* Scroll reveal base */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .85s cubic-bezier(.2,.7,.2,1),transform .85s cubic-bezier(.2,.7,.2,1);transition-delay:var(--d,0ms);will-change:opacity,transform}
.reveal-scale{transform:scale(.94) translateY(16px);transition:opacity .8s ease,transform .85s cubic-bezier(.2,.9,.2,1);transition-delay:var(--d,0ms)}
.reveal-drip{transform:translateY(-22px) scaleY(.85);transform-origin:top center;filter:blur(5px);transition:opacity .9s ease,transform .95s cubic-bezier(.3,1.3,.3,1),filter .6s ease;transition-delay:var(--d,0ms)}
.reveal.in,.reveal-scale.in,.reveal-drip.in{opacity:1;transform:none;filter:none}

/* Shimmering gold title */
.hero h1{
  background:linear-gradient(90deg,#fff 0%,#fff 38%,#f4dca6 48%,#ffffff 58%,#fff 100%);
  background-size:240% 100%;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  animation:ka-shimmer 6.5s linear infinite;
}

/* Kicker drops in like a seal */
.hero .kicker{animation:ka-drop 1s cubic-bezier(.3,1.3,.3,1) both}

/* Hero pack: breathing float + ribbon shine */
.pack{animation:ka-float 7.2s ease-in-out infinite;transform-origin:center}
.pack-ribbon{overflow:hidden}
.pack-ribbon::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(115deg,transparent 38%,rgba(255,255,255,.72) 50%,transparent 62%);
  transform:translateX(-120%) skewX(-18deg);
  animation:ka-ribbon 5.5s ease-in-out infinite;
}
.pack-seal{animation:ka-glow 4s ease-in-out infinite}

/* Buttons — shine sweep on hover */
.btn-primary{position:relative;overflow:hidden;isolation:isolate}
.btn-primary::after{
  content:"";position:absolute;top:0;left:0;width:55%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);
  transform:translateX(-140%) skewX(-22deg);
  pointer-events:none;
}
.btn-primary:hover::after{animation:ka-shine 1s ease forwards}
.btn-ghost{position:relative;overflow:hidden}
.btn-ghost::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(135deg,rgba(201,163,106,0),rgba(201,163,106,.18),rgba(201,163,106,0));
  opacity:0;transition:opacity .35s ease;
}
.btn-ghost:hover::before{opacity:1}

/* Cards — golden outline trace on hover */
.card{position:relative;overflow:hidden;isolation:isolate}
.card::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:linear-gradient(135deg,rgba(201,163,106,0) 20%,rgba(240,212,160,.85) 50%,rgba(201,163,106,0) 80%);
  background-size:220% 220%;
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .45s ease;pointer-events:none;
}
.card:hover::before{opacity:1;animation:ka-shimmer 2.4s linear infinite}
.card:hover{transform:translateY(-4px) rotate(-.15deg)}

/* Process steps — pulsing gold counters */
.step::before{animation:ka-glow 3.2s ease-in-out infinite}
.step{transition:transform .25s ease,border-color .25s ease,background .3s ease}
.step:hover{transform:translateY(-3px);border-color:rgba(201,163,106,.5);background:linear-gradient(180deg,rgba(201,163,106,.06),transparent),var(--bg-3)}

/* FAQ — animated underline + smoother open */
.faq summary{position:relative;padding-bottom:4px;transition:color .25s ease}
.faq summary:hover{color:var(--gold-2)}
.faq summary::before{
  content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;
  background:linear-gradient(90deg,var(--gold-2),transparent);
  transition:width .55s cubic-bezier(.2,.8,.2,1);
}
.faq details[open] summary::before{width:100%}
.faq summary::after{transition:transform .3s ease,color .3s ease}
.faq details[open] summary::after{transform:rotate(180deg)}

/* Section titles — elegant cocoa pod mark (SVG) */
section > .container > h2{position:relative;padding-left:62px}
section > .container > h2::before{
  content:"";position:absolute;left:0;top:50%;width:50px;height:30px;
  transform:translateY(-50%);
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 52 32'><defs><radialGradient id='b' cx='36%25' cy='30%25' r='82%25'><stop offset='0%25' stop-color='%23f7e2b2'/><stop offset='40%25' stop-color='%23d2a96d'/><stop offset='85%25' stop-color='%235a3820'/><stop offset='100%25' stop-color='%232a1610'/></radialGradient><linearGradient id='l' x1='0' x2='1' y1='1' y2='0'><stop offset='0' stop-color='%23a07940'/><stop offset='.5' stop-color='%23e6c892'/><stop offset='1' stop-color='%23c9a36a'/></linearGradient></defs><g><path d='M10 13 Q14 3 23 7 Q19 14 10 13 Z' fill='url(%23l)' opacity='.9'/><path d='M11 12 Q16 6 22 8' stroke='%23fff3d6' stroke-width='.5' fill='none' opacity='.6'/><path d='M42 13 Q38 3 29 7 Q33 14 42 13 Z' fill='url(%23l)' opacity='.9'/><path d='M41 12 Q36 6 30 8' stroke='%23fff3d6' stroke-width='.5' fill='none' opacity='.6'/><ellipse cx='26' cy='19' rx='15' ry='8.5' fill='url(%23b)'/><ellipse cx='26' cy='19' rx='15' ry='8.5' fill='none' stroke='%23f4dca6' stroke-width='.5' opacity='.45'/><ellipse cx='20' cy='14.5' rx='7' ry='2' fill='white' opacity='.28'/><path d='M12 19 Q26 26 40 19' stroke='%23140d09' stroke-width='1' fill='none' stroke-linecap='round' opacity='.85'/><circle cx='35' cy='13' r='1.1' fill='%23fff3d6'/><circle cx='38.5' cy='15' r='.5' fill='%23fff3d6' opacity='.7'/></g></svg>") no-repeat center/contain;
  filter:drop-shadow(0 4px 8px rgba(0,0,0,.55));
  animation:ka-bean 1s cubic-bezier(.2,1.3,.3,1) both;
}
@media (max-width:560px){
  section > .container > h2{padding-left:48px}
  section > .container > h2::before{width:38px;height:24px}
}
@media (max-width:400px){
  section > .container > h2{padding-left:0}
  section > .container > h2::before{display:none}
}

/* ============ Custom checkbox (form consent) ============ */
.form .consent{
  display:flex;gap:12px;align-items:flex-start;margin:18px 0;
  line-height:1.55;
}
.form .consent input[type="checkbox"]{
  appearance:none;-webkit-appearance:none;
  flex:0 0 20px;width:20px;height:20px;margin:2px 0 0;
  border:1.5px solid rgba(201,163,106,.55);border-radius:5px;
  background:var(--bg-2);cursor:pointer;position:relative;
  transition:border-color .2s ease,background .25s ease,box-shadow .25s ease;
}
.form .consent input[type="checkbox"]:hover{border-color:var(--gold-2)}
.form .consent input[type="checkbox"]:focus-visible{
  outline:2px solid var(--gold-2);outline-offset:3px;
}
.form .consent input[type="checkbox"]:checked{
  background:linear-gradient(180deg,var(--gold-2),var(--gold));
  border-color:var(--gold-2);
  box-shadow:0 4px 12px rgba(201,163,106,.35);
}
.form .consent input[type="checkbox"]:checked::after{
  content:"";position:absolute;left:6px;top:1px;width:5px;height:11px;
  border:solid #241812;border-width:0 2.5px 2.5px 0;
  transform:rotate(45deg);
}
.form .consent label{
  margin:0;padding:0;color:var(--cream);cursor:pointer;flex:1;
  font-size:.93rem;line-height:1.55;
}

/* ============ Horizontally scrollable tables ============ */
.table-scroll{
  overflow-x:auto;-webkit-overflow-scrolling:touch;
  border:1px solid var(--line);border-radius:var(--radius);
  background:var(--bg-3);margin-top:18px;
  scrollbar-width:thin;scrollbar-color:var(--gold) var(--bg-2);
  box-shadow:inset -10px 0 14px -14px rgba(0,0,0,.8);
}
.table-scroll .price-table{margin-top:0;border:0;border-radius:0;min-width:560px}
.table-scroll::-webkit-scrollbar{height:8px}
.table-scroll::-webkit-scrollbar-track{background:var(--bg-2)}
.table-scroll::-webkit-scrollbar-thumb{
  background:linear-gradient(90deg,var(--gold),var(--gold-2));border-radius:4px;
}

/* ============ Contact list — İletişim page ============ */
.contact-list{
  list-style:none;margin:18px 0 0;padding:0;
  display:flex;flex-direction:column;gap:12px;
}
.contact-list li{
  display:flex;gap:14px;align-items:center;
  padding:14px 16px;border:1px solid var(--line);border-radius:12px;
  background:linear-gradient(180deg,rgba(201,163,106,.05),rgba(255,255,255,0));
  transition:transform .3s ease,border-color .3s ease,background .4s ease,box-shadow .3s ease;
}
.contact-list li:hover{
  transform:translateX(5px);border-color:rgba(201,163,106,.5);
  background:linear-gradient(180deg,rgba(201,163,106,.11),rgba(255,255,255,0));
  box-shadow:0 10px 26px rgba(0,0,0,.3);
}
.contact-list .ci-ico{
  flex:0 0 44px;width:44px;height:44px;border-radius:50%;
  display:grid;place-items:center;color:#241812;
  background:radial-gradient(circle at 32% 28%,#f4dca6,#c9a36a 55%,#4a2d1e 95%);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.2),0 8px 18px rgba(0,0,0,.45);
}
.contact-list .ci-ico svg{width:20px;height:20px;display:block}
.contact-list .ci-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.contact-list .ci-lbl{
  font-size:.7rem;letter-spacing:1.4px;text-transform:uppercase;
  color:var(--gold-2);font-weight:600;
}
.contact-list .ci-val,.contact-list .ci-main a{
  color:#fff;font-weight:500;font-size:.98rem;word-break:break-word;
}
.contact-list .ci-main a:hover{color:var(--gold-2)}

/* ============ Smooth FAQ open/close ============ */
.faq .details-body{
  overflow:hidden;max-height:0;opacity:0;
  transition:max-height .45s cubic-bezier(.4,0,.2,1),opacity .3s ease;
}
.faq details[open] .details-body{opacity:1}

/* ============ Epic hero load sequence ============ */
.ka-ready .hero .kicker,
.ka-ready .hero h1,
.ka-ready .hero p.lead,
.ka-ready .hero .hero-cta,
.ka-ready .hero .note,
.ka-ready .hero .media-img,
.ka-ready .hero .pack{opacity:0}

.ka-ready.intro-done .hero .kicker{animation:ka-kick 1s cubic-bezier(.2,1.3,.3,1) .1s both}
.ka-ready.intro-done .hero h1{animation:ka-mask 1.15s cubic-bezier(.6,0,.2,1) .28s both,ka-shimmer 6.5s linear 1.5s infinite}
.ka-ready.intro-done .hero p.lead{animation:ka-rise .95s cubic-bezier(.2,.8,.2,1) .58s both}
.ka-ready.intro-done .hero .hero-cta{animation:ka-rise 1s cubic-bezier(.2,1.3,.3,1) .78s both}
.ka-ready.intro-done .hero .note{animation:ka-rise .85s ease 1s both}
.ka-ready.intro-done .hero .media-img,
.ka-ready.intro-done .hero .pack{animation:ka-pop 1.15s cubic-bezier(.2,1.5,.3,1) .45s both,ka-float 7.2s ease-in-out 2s infinite}

@keyframes ka-kick{
  0%{opacity:0;transform:translate(-16px,-6px) rotate(-5deg)}
  60%{opacity:1}
  100%{opacity:1;transform:translate(0,0) rotate(0)}
}
@keyframes ka-rise{
  0%{opacity:0;transform:translateY(26px);filter:blur(4px)}
  60%{opacity:1}
  100%{opacity:1;transform:translateY(0);filter:blur(0)}
}
@keyframes ka-pop{
  0%{opacity:0;transform:scale(.8) translateY(22px) rotate(-2deg)}
  65%{opacity:1;transform:scale(1.02) translateY(-2px) rotate(0)}
  100%{opacity:1;transform:scale(1) translateY(0)}
}
@keyframes ka-mask{
  0%{opacity:0;clip-path:inset(0 100% 0 0);transform:translateY(10px)}
  55%{opacity:1}
  100%{opacity:1;clip-path:inset(0 0 0 0);transform:translateY(0)}
}

/* Load tick — rhythmic staggered reveal for on-screen sections */
.ka-ready.intro-done section:first-of-type .reveal,
.ka-ready.intro-done section:first-of-type .reveal-scale,
.ka-ready.intro-done section:first-of-type .reveal-drip{
  transition-delay:calc(var(--d,0ms) + 1.1s);
}

/* Scroll progress — golden river */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:0;z-index:60;pointer-events:none;
  background:linear-gradient(90deg,var(--gold),var(--gold-2),#fff3d6,var(--gold-2),var(--gold));
  background-size:280% 100%;
  box-shadow:0 0 12px rgba(240,212,160,.55),0 0 2px rgba(240,212,160,.8);
  animation:ka-shimmer 3.2s linear infinite;
}

/* Floating gold dust layer */
.gold-dust{
  position:fixed;inset:0;pointer-events:none;z-index:2;
  opacity:.55;mix-blend-mode:screen;
}

/* Intro curtain — melting chocolate bars */
.intro-curtain{
  position:fixed;inset:0;z-index:9999;display:flex;pointer-events:none;overflow:hidden;
}
.intro-curtain .bar{
  flex:1 1 0;
  background:
    linear-gradient(180deg,#3b2418 0%,#2a1c15 45%,#140d09 100%);
  box-shadow:inset 1px 0 0 rgba(201,163,106,.08),inset -1px 0 0 rgba(0,0,0,.4);
  transform:translateY(0);
  animation:ka-melt 1.2s cubic-bezier(.7,.05,.3,1) forwards;
}
.intro-curtain .bar:nth-child(1){animation-delay:.05s}
.intro-curtain .bar:nth-child(2){animation-delay:.16s}
.intro-curtain .bar:nth-child(3){animation-delay:.26s}
.intro-curtain .bar:nth-child(4){animation-delay:.12s}
.intro-curtain .bar:nth-child(5){animation-delay:.22s}
.intro-curtain .bar:nth-child(6){animation-delay:.08s}
.intro-curtain .bar:nth-child(7){animation-delay:.18s}
.intro-curtain .bar:nth-child(8){animation-delay:.04s}
.intro-curtain .seal{
  position:absolute;left:50%;top:50%;width:120px;height:120px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#f4dca6,#c9a36a 46%,#4a2d1e 85%);
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.22),0 22px 55px rgba(0,0,0,.65);
  display:grid;place-items:center;color:#241812;font-weight:800;font-size:.72rem;letter-spacing:1.6px;
  transform:translate(-50%,-50%) scale(.3);
  animation:ka-seal 1.15s cubic-bezier(.2,1.4,.4,1) forwards;
  font-family:var(--font);
}
.intro-done .intro-curtain{display:none}

/* Honour reduced motion */
@media (prefers-reduced-motion:reduce){
  .hero h1{animation:none;color:#fff;-webkit-text-fill-color:#fff;background:none}
  .pack,.pack-ribbon::after,.pack-seal,.step::before,.scroll-progress,.intro-curtain .bar,.intro-curtain .seal{animation:none!important}
  .reveal,.reveal-scale,.reveal-drip{opacity:1!important;transform:none!important;filter:none!important}
  .gold-dust{display:none}
  .ka-ready .hero .kicker,
  .ka-ready .hero h1,
  .ka-ready .hero p.lead,
  .ka-ready .hero .hero-cta,
  .ka-ready .hero .note,
  .ka-ready .hero .media-img,
  .ka-ready .hero .pack{opacity:1!important;animation:none!important;transform:none!important}
}

/* =====================================================
   STYLIZED LISTS — themed bullets & hover states
   ===================================================== */

/* Card bullet lists — cocoa-bean markers */
.card ul{list-style:none;padding:0;margin:12px 0 0}
.card ul li{
  position:relative;padding:5px 0 5px 26px;
  transition:color .25s ease,transform .25s ease;
}
.card ul li::before{
  content:"";position:absolute;left:2px;top:.85em;
  width:12px;height:8px;border-radius:50%;
  background:
    radial-gradient(ellipse at 32% 30%,#f7e2b2 0%,#c9a36a 50%,#3b2418 100%);
  box-shadow:inset 0 0 0 .5px rgba(255,255,255,.2),0 2px 5px rgba(0,0,0,.5);
  transform:translateY(-50%) rotate(-8deg);
  transition:transform .35s cubic-bezier(.2,1.4,.3,1);
}
.card ul li::after{
  content:"";position:absolute;left:5px;top:.85em;
  width:6px;height:.5px;background:rgba(0,0,0,.6);
  transform:translateY(-50%) rotate(-8deg);
}
.card:hover ul li::before{transform:translateY(-50%) rotate(4deg) scale(1.1)}
.card ul li:hover{color:var(--gold-2)}

/* Info block lists + general content lists */
.info .block ul,
section > .container > ul,
.form-standalone ul{
  list-style:none;padding:0;margin:12px 0;
}
.info .block ul li,
section > .container > ul li,
.form-standalone ul li{
  position:relative;padding:6px 0 6px 28px;color:var(--cream);
}
.info .block ul li::before,
section > .container > ul li::before,
.form-standalone ul li::before{
  content:"";position:absolute;left:4px;top:.9em;
  width:14px;height:1px;
  background:linear-gradient(90deg,var(--gold-2),var(--gold),transparent);
  transform:translateY(-50%);
  transition:width .3s ease;
}
.info .block ul li::after,
section > .container > ul li::after,
.form-standalone ul li::after{
  content:"";position:absolute;left:0;top:.9em;
  width:6px;height:6px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,#f4dca6,#c9a36a 60%,#3b2418);
  box-shadow:0 0 8px rgba(201,163,106,.5);
  transform:translateY(-50%);
}
.info .block ul li:hover::before,
section > .container > ul li:hover::before,
.form-standalone ul li:hover::before{width:22px}

/* Footer link lists — elegant slide */
.foot-grid ul{list-style:none;padding:0;margin:0}
.foot-grid li{
  position:relative;padding:6px 0 6px 20px;margin:2px 0;
  transition:padding-left .3s cubic-bezier(.2,.8,.2,1);
}
.foot-grid li::before{
  content:"";position:absolute;left:0;top:50%;
  width:10px;height:1px;
  background:linear-gradient(90deg,var(--gold-2),transparent);
  transform:translateY(-50%);
  transition:width .3s ease,background .3s ease;
}
.foot-grid li::after{
  content:"";position:absolute;left:0;top:50%;
  width:4px;height:4px;border-radius:50%;
  background:var(--gold);
  transform:translateY(-50%) scale(.8);
  box-shadow:0 0 6px rgba(201,163,106,.4);
  opacity:.7;transition:opacity .3s ease,transform .3s ease;
}
.foot-grid li:hover{padding-left:26px}
.foot-grid li:hover::before{width:16px;background:linear-gradient(90deg,#fff3d6,var(--gold))}
.foot-grid li:hover::after{opacity:1;transform:translateY(-50%) scale(1.15)}
.foot-grid li a{color:var(--cream);transition:color .25s ease}
.foot-grid li:hover a{color:var(--gold-2)}

/* Legal footer list keeps plain, unaffected */
.legal{list-style:none}

/* Ordered lists (if used) — gold serif numerals */
section > .container > ol,
.form-standalone ol,
.info .block ol{
  list-style:none;counter-reset:ka;padding:0;margin:14px 0;
}
section > .container > ol li,
.form-standalone ol li,
.info .block ol li{
  position:relative;padding:6px 0 6px 36px;counter-increment:ka;color:var(--cream);
}
section > .container > ol li::before,
.form-standalone ol li::before,
.info .block ol li::before{
  content:counter(ka,decimal-leading-zero);
  position:absolute;left:0;top:.5em;
  font-family:"Segoe UI",Georgia,serif;
  font-size:.95rem;font-weight:700;
  background:linear-gradient(180deg,#fff3d6,var(--gold));
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  min-width:26px;text-align:left;
  border-right:1px solid rgba(201,163,106,.35);
  padding-right:6px;
}
