  :root{
    --ivory:#f3efe6;
    --ivory-deep:#ebe6d9;
    --ink:#15130e;
    --ink-soft:#8c8676;
    --brass:#b3873e;
    --brass-soft:#c9a566;
    --line:rgba(21,19,14,0.14);
    --line-soft:rgba(21,19,14,0.07);
    --line-light:rgba(243,239,230,0.16);
    --serif:'Cormorant Garamond', serif;
    --sans:'Jost', sans-serif;
    --ease:cubic-bezier(.16,1,.3,1);
  }
  *{margin:0;padding:0;box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    font-family:var(--sans);
    font-weight:300;
    background:var(--ivory);
    color:var(--ink);
    line-height:1.6;
    overflow-x:hidden;
    -webkit-font-smoothing:antialiased;
  }

  /* grain texture overlay */
  body::before{
    content:"";
    position:fixed;
    inset:0;
    z-index:9999;
    pointer-events:none;
    opacity:0.045;
    mix-blend-mode:multiply;
    background-image:url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMDAiIGhlaWdodD0iMjAwIj48ZmlsdGVyIGlkPSJuIj48ZmVUdXJidWxlbmNlIHR5cGU9ImZyYWN0YWxOb2lzZSIgYmFzZUZyZXF1ZW5jeT0iMC45IiBudW1PY3RhdmVzPSIyIiBzdGl0Y2hUaWxlcz0ic3RpdGNoIi8+PC9maWx0ZXI+PHJlY3Qgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgZmlsdGVyPSJ1cmwoI24pIi8+PC9zdmc+");
  }

  ::selection{ background:var(--ink); color:var(--ivory); }

  a{ color:inherit; text-decoration:none; }
  img{ display:block; max-width:100%; }

  .container{
    max-width:1240px;
    margin:0 auto;
    padding:0 32px;
  }

  h1,h2,h3,h4{ font-family:var(--serif); font-weight:500; letter-spacing:-0.01em; }

  .eyebrow{
    font-size:11px;
    letter-spacing:0.38em;
    text-transform:uppercase;
    color:var(--brass);
    font-weight:500;
  }

  /* ---------- reveal-on-load ---------- */
  .reveal{
    opacity:0;
    transform:translateY(28px);
    transition:opacity 1s var(--ease), transform 1s var(--ease);
  }
  .reveal.in{ opacity:1; transform:translateY(0); }
  .reveal-d1{ transition-delay:.08s; }
  .reveal-d2{ transition-delay:.16s; }
  .reveal-d3{ transition-delay:.24s; }
  .reveal-d4{ transition-delay:.32s; }

  /* ---------- barber pole stripe ---------- */
  .pole, .poleh{
    position:absolute;
    background:repeating-linear-gradient(45deg,
      var(--brass) 0 14px,
      var(--ivory) 14px 28px,
      var(--ink) 28px 42px,
      var(--ivory) 42px 56px);
    z-index:1;
    pointer-events:none;
  }
  .pole{
    top:0; bottom:0; width:10px;
    background-size:80px 80px;
    animation:pole 3s linear infinite;
  }
  .poleh{
    left:0; right:0; height:10px;
    background-size:80px 80px;
    animation:poleh 3s linear infinite;
  }
  @keyframes pole{ from{ background-position:0 0; } to{ background-position:0 80px; } }
  @keyframes poleh{ from{ background-position:0 0; } to{ background-position:80px 0; } }

  /* ================= NAVBAR ================= */
  .navbar{
    position:fixed;
    top:0; left:0; right:0;
    z-index:500;
    padding:26px 0;
    background:linear-gradient(rgba(21,19,14,0.85), rgba(21,19,14,0.5));
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    border-bottom:1px solid transparent;
    transition:padding .5s var(--ease), background .5s var(--ease), border-color .5s var(--ease);
  }
  .navbar.scrolled{
    padding:16px 0;
    background:linear-gradient(rgba(21,19,14,0.96), rgba(21,19,14,0.86));
    border-bottom:1px solid var(--line-light);
  }
  .nav-inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:24px;
  }
  .brand{
    display:flex;
    align-items:center;
    gap:14px;
  }
  .brand-badge{
    width:40px; height:40px;
    border-radius:50%;
    flex-shrink:0;
    filter:brightness(0) invert(1);
    transition:transform .6s var(--ease);
  }
  .brand:hover .brand-badge{ transform:rotate(28deg); }
  .wordmark{
    display:flex;
    flex-direction:column;
    line-height:1.05;
    color:var(--ivory);
  }
  .wordmark .l1{
    font-family:var(--serif);
    font-style:italic;
    font-size:18px;
    letter-spacing:0.04em;
  }
  .wordmark .l2{
    font-size:10px;
    letter-spacing:0.36em;
    color:var(--brass-soft);
    font-weight:500;
    margin-top:3px;
  }
  .nav-links{
    display:flex;
    align-items:center;
    gap:38px;
  }
  .nav-link{
    font-size:13px;
    font-weight:400;
    letter-spacing:0.06em;
    text-transform:uppercase;
    color:var(--ivory);
    position:relative;
    padding:4px 0;
  }
  .nav-link::after{
    content:"";
    position:absolute;
    left:0; right:100%;
    bottom:0;
    height:1px;
    background:var(--brass);
    transition:right .4s var(--ease);
  }
  .nav-link:hover{ color:var(--brass-soft); }
  .nav-link:hover::after{ right:0; }
  .nav-link.active{ color:var(--brass-soft); }
  .nav-link.active::after{ right:0; }
  .btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    font-family:var(--sans);
    font-size:11px;
    font-weight:500;
    letter-spacing:0.26em;
    text-transform:uppercase;
    padding:15px 30px;
    border-radius:2px;
    border:1px solid var(--brass);
    color:var(--brass-soft);
    cursor:pointer;
    transition:all .4s var(--ease);
    white-space:nowrap;
    background:transparent;
  }
  .btn-solid{
    background:var(--brass);
    color:var(--ink);
    border-color:var(--brass);
  }
  .btn-solid:hover{
    background:transparent;
    color:var(--brass-soft);
  }
  .btn-outline{
    background:transparent;
    color:var(--brass-soft);
    border-color:var(--brass-soft);
  }
  .btn-outline:hover{
    background:var(--brass-soft);
    color:var(--ink);
    border-color:var(--brass-soft);
  }
  .btn-ghost{
    border-color:var(--line);
    color:var(--ink);
    background:transparent;
  }
  .btn-ghost:hover{ border-color:var(--ink); background:var(--ivory-deep); }
  .btn-sm{ padding:12px 22px; font-size:10px; letter-spacing:0.2em; }
  .nav-cta{ display:none; }
  @media(min-width:880px){ .nav-cta{ display:inline-flex; } }
  .nav-links{ display:none; }
  @media(min-width:880px){ .nav-links{ display:flex; } }

  .burger{
    display:flex;
    width:42px; height:42px;
    border-radius:50%;
    border:1px solid var(--line-light);
    align-items:center;
    justify-content:center;
    cursor:pointer;
    flex-direction:column;
    gap:5px;
  }
  @media(min-width:880px){ .burger{ display:none; } }
  .burger span{
    width:16px; height:1px; background:var(--ivory);
    transition:transform .35s var(--ease), opacity .35s var(--ease);
  }
  .burger.active span:nth-child(1){ transform:translateY(6px) rotate(45deg); }
  .burger.active span:nth-child(2){ opacity:0; }
  .burger.active span:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }

  .mobile-menu{
    position:fixed;
    inset:0 0 auto 0;
    top:0;
    background:var(--ink);
    z-index:450;
    padding:110px 32px 40px;
    display:flex;
    flex-direction:column;
    gap:28px;
    transform:translateY(-100%);
    transition:transform .55s var(--ease);
  }
  .mobile-menu.open{ transform:translateY(0); }
  .mobile-menu a{
    font-family:var(--serif);
    font-size:32px;
    font-style:italic;
    color:var(--ivory);
    border-bottom:1px solid var(--line-light);
    padding-bottom:18px;
  }

  /* ================= HERO ================= */
  .hero{
    position:relative;
    padding:170px 0 80px;
    overflow:hidden;
    background:
      radial-gradient(1100px 560px at 80% -10%, rgba(179,135,62,0.16), transparent 60%),
      radial-gradient(900px 500px at 5% 110%, rgba(179,135,62,0.08), transparent 55%),
      var(--ink);
    color:var(--ivory);
  }
  .hero-grid{
    display:grid;
    grid-template-columns:1fr;
    gap:48px;
    align-items:center;
    position:relative;
    z-index:2;
  }
  @media(min-width:980px){
    .hero-grid{ grid-template-columns:1.15fr 0.85fr; gap:40px; }
  }
  .hero-copy h1{
    margin-top:18px;
    font-family:var(--sans);
    font-weight:400;
    text-transform:uppercase;
    letter-spacing:0.1em;
    font-size:clamp(34px, 5.6vw, 60px);
    line-height:1.3;
  }
  .hero-copy h1 em{
    display:block;
    font-family:var(--serif);
    font-style:italic;
    font-weight:500;
    text-transform:none;
    letter-spacing:0.01em;
    color:var(--brass-soft);
    font-size:clamp(38px, 7vw, 74px);
  }
  .hero-copy p{
    margin-top:26px;
    max-width:480px;
    font-size:17px;
    color:var(--ink-soft);
    font-weight:300;
  }
  .hero-actions{
    margin-top:40px;
    display:flex;
    flex-wrap:wrap;
    gap:16px;
  }
  .hero-visual{
    position:relative;
    display:flex;
    align-items:center;
    justify-content:center;
    min-height:340px;
    z-index:2;
  }
  .ring-wrap{
    position:relative;
    width:min(380px, 80vw);
    aspect-ratio:1;
  }
  .spin-ring{
    position:absolute;
    inset:0;
    border-radius:50%;
    border:1px solid var(--line-light);
    animation:spin 50s linear infinite;
  }
  .spin-ring.r2{
    inset:34px;
    border-style:dashed;
    animation:spin 70s linear infinite reverse;
  }
  .spin-ring::before{
    content:"";
    position:absolute;
    top:-1px; left:50%;
    width:7px; height:7px;
    background:var(--brass);
    border-radius:50%;
    transform:translateX(-50%);
  }
  @keyframes spin{ to{ transform:rotate(360deg); } }
  .hero-logo-img{
    position:absolute;
    inset:60px;
    width:calc(100% - 120px);
    height:calc(100% - 120px);
    border-radius:50%;
    filter:brightness(0) invert(1);
    animation:floaty 7s ease-in-out infinite;
  }
  @keyframes floaty{
    0%,100%{ transform:translateY(0); }
    50%{ transform:translateY(-12px); }
  }

  .stats-strip{
    margin-top:90px;
    border-top:1px solid var(--line-light);
    border-bottom:1px solid var(--line-light);
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:0;
    position:relative;
    z-index:2;
  }
  @media(min-width:760px){ .stats-strip{ grid-template-columns:repeat(4,1fr); } }
  .stat{
    padding:30px 24px;
    border-right:1px solid var(--line-light);
  }
  .stat:last-child{ border-right:none; }
  .stat .num{
    font-family:var(--serif);
    font-size:clamp(28px,4vw,40px);
    font-style:italic;
    color:var(--brass-soft);
  }
  .stat .lbl{
    margin-top:6px;
    font-size:11px;
    letter-spacing:0.18em;
    text-transform:uppercase;
    color:var(--ink-soft);
  }

  /* ================= SECTION GENERIC ================= */
  section{ padding:120px 0; position:relative; }
  .section-head{
    max-width:640px;
    margin-bottom:64px;
  }
  .section-head h2{
    margin-top:14px;
    font-family:var(--sans);
    font-weight:400;
    text-transform:uppercase;
    letter-spacing:0.16em;
    font-size:clamp(26px, 4vw, 44px);
    line-height:1.4;
  }
  .section-head h2 em{
    font-family:var(--serif);
    font-style:italic;
    font-weight:600;
    text-transform:none;
    letter-spacing:0.01em;
    color:var(--brass);
  }
  .section-head p{
    margin-top:18px;
    color:var(--ink-soft);
    font-size:16px;
    font-weight:300;
    max-width:520px;
  }
  .divider{
    height:1px;
    background:var(--line);
    border:none;
  }

  /* ================= BOOKING WIZARD ================= */
  .booking-panel{
    background:#fff;
    border:1px solid var(--line);
    border-radius:4px;
    padding:clamp(24px, 5vw, 56px);
    box-shadow:0 40px 100px -40px rgba(21,19,14,0.18);
  }
  .progress{
    display:flex;
    align-items:flex-start;
    gap:6px;
    margin-bottom:54px;
    overflow-x:auto;
    padding-bottom:6px;
  }
  .progress-step{
    flex:1;
    min-width:84px;
    position:relative;
    padding-top:14px;
  }
  .progress-step::before{
    content:"";
    position:absolute;
    top:0; left:0; right:0;
    height:2px;
    background:var(--line);
    transition:background .5s var(--ease);
  }
  .progress-step.active::before,
  .progress-step.done::before{ background:var(--brass); }
  .progress-step .ps-num{
    font-family:var(--serif);
    font-style:italic;
    font-size:22px;
    color:var(--line);
    transition:color .4s var(--ease);
  }
  .progress-step.active .ps-num,
  .progress-step.done .ps-num{ color:var(--brass); }
  .progress-step .ps-lbl{
    margin-top:4px;
    font-size:11px;
    letter-spacing:0.12em;
    text-transform:uppercase;
    color:var(--ink-soft);
    display:none;
  }
  @media(min-width:640px){ .progress-step .ps-lbl{ display:block; } }

  .step-pane{ display:none; }
  .step-pane.active{
    display:block;
    animation:fadein .55s var(--ease);
  }
  @keyframes fadein{
    from{ opacity:0; transform:translateY(16px); }
    to{ opacity:1; transform:translateY(0); }
  }
  .step-title{
    font-family:var(--serif);
    font-style:italic;
    font-weight:600;
    font-size:clamp(24px,3.4vw,32px);
    margin-bottom:6px;
  }
  .step-sub{
    color:var(--ink-soft);
    font-size:14.5px;
    font-weight:300;
    margin-bottom:36px;
  }

  /* service / barber cards */
  .choice-grid{
    display:grid;
    grid-template-columns:1fr;
    gap:16px;
  }
  @media(min-width:640px){ .choice-grid{ grid-template-columns:repeat(3,1fr); } }
  @media(min-width:640px){ .choice-grid.cols-2{ grid-template-columns:repeat(2,1fr); } }
  .choice-card{
    border:1px solid var(--line);
    border-radius:4px;
    padding:26px 24px;
    cursor:pointer;
    transition:border-color .35s var(--ease), transform .35s var(--ease), box-shadow .35s var(--ease), background .35s var(--ease);
    position:relative;
    overflow:hidden;
  }
  .choice-card::after{
    content:"";
    position:absolute;
    top:18px; right:18px;
    width:20px; height:20px;
    border-radius:50%;
    border:1.4px solid var(--line);
    transition:all .35s var(--ease);
  }
  .choice-card.selected::after{
    border-color:var(--brass);
    background:radial-gradient(circle, var(--brass) 0 38%, transparent 40%);
  }
  .choice-card:hover{
    transform:translateY(-4px);
    box-shadow:0 24px 60px -36px rgba(21,19,14,0.35);
  }
  .choice-card.selected{
    border-color:var(--brass);
    background:var(--ivory);
  }
  .choice-card h4{
    font-style:italic;
    font-size:21px;
    margin-bottom:8px;
    padding-right:30px;
  }
  .choice-card .meta{
    font-size:13px;
    color:var(--ink-soft);
    display:flex;
    flex-direction:column;
    gap:4px;
  }
  .choice-card .price{
    margin-top:14px;
    font-family:var(--serif);
    font-style:italic;
    font-size:20px;
    color:var(--brass);
  }
  .barber-card-head{
    display:flex;
    align-items:center;
    gap:14px;
    margin-bottom:14px;
  }
  .barber-avatar{
    width:54px; height:54px;
    border-radius:50%;
    border:1px solid var(--line);
    display:flex;
    align-items:center;
    justify-content:center;
    font-family:var(--serif);
    font-style:italic;
    font-size:20px;
    background:var(--ivory);
    flex-shrink:0;
  }
  .tag{
    display:inline-block;
    font-size:10.5px;
    letter-spacing:0.12em;
    text-transform:uppercase;
    color:var(--brass);
    border:1px solid var(--line);
    border-radius:2px;
    padding:3px 10px;
    margin-top:4px;
  }

  /* date / time */
  .date-row{
    display:flex;
    gap:12px;
    overflow-x:auto;
    padding-bottom:10px;
    margin-bottom:34px;
  }
  .date-pill{
    flex-shrink:0;
    min-width:84px;
    border:1px solid var(--line);
    border-radius:4px;
    padding:16px 14px;
    text-align:center;
    cursor:pointer;
    transition:all .3s var(--ease);
  }
  .date-pill:hover{ border-color:var(--brass); transform:translateY(-3px); }
  .date-pill.selected{ background:var(--ink); border-color:var(--ink); color:var(--ivory); }
  .date-pill.selected .dom{ color:var(--brass-soft); }
  .date-pill .dow{ font-size:11px; letter-spacing:0.12em; text-transform:uppercase; opacity:.7; }
  .date-pill .dom{ font-family:var(--serif); font-style:italic; font-size:26px; margin:4px 0; }
  .date-pill .mon{ font-size:11px; letter-spacing:0.1em; text-transform:uppercase; opacity:.7; }

  .time-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:12px;
  }
  @media(min-width:560px){ .time-grid{ grid-template-columns:repeat(3,1fr); } }
  @media(min-width:880px){ .time-grid{ grid-template-columns:repeat(4,1fr); } }
  .time-slot{
    border:1px solid var(--line);
    border-radius:4px;
    padding:16px 10px;
    text-align:center;
    font-size:14.5px;
    font-weight:500;
    cursor:pointer;
    transition:all .3s var(--ease);
  }
  .time-slot:hover:not(.full){ border-color:var(--brass); transform:translateY(-3px); }
  .time-slot.selected{ background:var(--ink); color:var(--ivory); border-color:var(--ink); }
  .time-slot.full{
    text-decoration:line-through;
    color:#b9b3a8;
    cursor:not-allowed;
    background:var(--ivory-deep);
  }

  /* form */
  .form-grid{
    display:grid;
    grid-template-columns:1fr;
    gap:22px;
  }
  @media(min-width:680px){ .form-grid{ grid-template-columns:1fr 1fr; } }
  .field{ display:flex; flex-direction:column; gap:8px; }
  .field.full{ grid-column:1/-1; }
  .field label{
    font-size:11px;
    letter-spacing:0.2em;
    text-transform:uppercase;
    color:var(--ink-soft);
    font-weight:500;
  }
  .field input, .field textarea{
    font-family:var(--sans);
    font-size:15px;
    font-weight:300;
    padding:15px 18px;
    border:1px solid var(--line);
    border-radius:4px;
    background:var(--ivory);
    color:var(--ink);
    transition:border-color .3s var(--ease), background .3s var(--ease);
    resize:vertical;
  }
  .field input:focus, .field textarea:focus{
    outline:none;
    border-color:var(--brass);
    background:#fff;
  }
  .field .err{
    font-size:12px;
    color:#9a3b2c;
    min-height:16px;
  }
  .addon-list{
    display:flex;
    flex-direction:column;
    gap:14px;
  }
  .addon{
    display:flex;
    align-items:center;
    justify-content:space-between;
    border:1px solid var(--line);
    border-radius:4px;
    padding:18px 20px;
    cursor:pointer;
    transition:border-color .3s var(--ease), background .3s var(--ease);
  }
  .addon:hover{ border-color:var(--brass); }
  .addon.checked{ border-color:var(--brass); background:var(--ivory); }
  .addon-left{ display:flex; align-items:center; gap:16px; }
  .checkbox{
    width:22px; height:22px;
    border:1.4px solid var(--line);
    border-radius:2px;
    flex-shrink:0;
    display:flex; align-items:center; justify-content:center;
    transition:all .25s var(--ease);
  }
  .addon.checked .checkbox{ background:var(--brass); border-color:var(--brass); }
  .checkbox svg{ opacity:0; transform:scale(.5); transition:all .25s var(--ease); }
  .addon.checked .checkbox svg{ opacity:1; transform:scale(1); }
  .addon-name{ font-weight:500; font-size:15px; }
  .addon-desc{ font-size:12.5px; color:var(--ink-soft); margin-top:2px; }
  .addon-price{ font-family:var(--serif); font-style:italic; font-size:17px; color:var(--brass); }

  /* payment */
  .pay-summary{
    border:1px solid var(--line);
    border-radius:4px;
    padding:28px;
    margin-bottom:36px;
  }
  .pay-row{
    display:flex;
    justify-content:space-between;
    font-size:14.5px;
    padding:10px 0;
    border-bottom:1px solid var(--line-soft);
    color:var(--ink-soft);
  }
  .pay-row:last-of-type{ border-bottom:none; }
  .pay-row.total{
    margin-top:8px;
    padding-top:18px;
    border-top:1px solid var(--line);
    border-bottom:none;
    color:var(--ink);
    font-weight:600;
    font-size:18px;
  }
  .pay-row.total .amt{ font-family:var(--serif); font-style:italic; font-size:26px; color:var(--brass); }

  .pay-methods{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px;
    margin-bottom:30px;
  }
  .pay-method{
    border:1px solid var(--line);
    border-radius:4px;
    padding:22px 18px;
    text-align:center;
    cursor:pointer;
    transition:all .3s var(--ease);
  }
  .pay-method:hover{ border-color:var(--brass); transform:translateY(-3px); }
  .pay-method.selected{ border-color:var(--brass); background:var(--ivory); }
  .pay-method .pm-name{ font-family:var(--serif); font-style:italic; font-size:19px; }
  .pay-method .pm-desc{ font-size:12px; color:var(--ink-soft); margin-top:4px; }

  .pay-detail{
    border:1px solid var(--line);
    border-radius:4px;
    padding:30px;
    display:none;
  }
  .pay-detail.show{ display:block; animation:fadein .5s var(--ease); }
  .qris-box{
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:18px;
    text-align:center;
  }
  .qris-box img{
    width:200px; height:200px;
    border:1px solid var(--line);
    border-radius:4px;
    padding:14px;
    background:#fff;
  }
  .va-row{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
    background:var(--ivory);
    border:1px solid var(--line);
    border-radius:4px;
    padding:18px 22px;
    margin-bottom:22px;
    flex-wrap:wrap;
  }
  .va-num{
    font-family:var(--serif);
    font-style:italic;
    font-size:22px;
    letter-spacing:0.04em;
    color:var(--brass);
  }
  .copy-btn{
    border:1px solid var(--ink);
    background:transparent;
    border-radius:2px;
    padding:9px 20px;
    font-size:11px;
    letter-spacing:0.18em;
    text-transform:uppercase;
    font-weight:500;
    cursor:pointer;
    transition:all .3s var(--ease);
    font-family:var(--sans);
  }
  .copy-btn:hover{ background:var(--ink); color:var(--ivory); }
  .va-steps{
    counter-reset:step;
    display:flex;
    flex-direction:column;
    gap:12px;
  }
  .va-steps li{
    list-style:none;
    display:flex;
    gap:14px;
    font-size:14px;
    color:var(--ink-soft);
  }
  .va-steps li::before{
    counter-increment:step;
    content:counter(step);
    flex-shrink:0;
    width:26px; height:26px;
    border-radius:50%;
    border:1px solid var(--line);
    display:flex; align-items:center; justify-content:center;
    font-size:12px;
    font-weight:600;
    color:var(--brass);
  }

  /* bukti transfer upload */
  .upload-box{
    border:1px solid var(--line);
    border-radius:4px;
    padding:30px;
    margin-top:22px;
  }
  .upload-row{
    display:flex;
    align-items:center;
    gap:16px;
    flex-wrap:wrap;
  }
  .upload-btn{
    border:1px solid var(--ink);
    background:transparent;
    border-radius:2px;
    padding:9px 20px;
    font-size:11px;
    letter-spacing:0.18em;
    text-transform:uppercase;
    font-weight:500;
    cursor:pointer;
    transition:all .3s var(--ease);
    font-family:var(--sans);
    display:inline-block;
  }
  .upload-btn:hover{ background:var(--ink); color:var(--ivory); }
  .upload-filename{
    font-size:13px;
    color:var(--ink-soft);
  }
  .upload-preview{
    margin-top:18px;
    display:flex;
    align-items:center;
    gap:18px;
    flex-wrap:wrap;
  }
  .upload-preview img{
    width:140px;
    max-height:140px;
    object-fit:cover;
    border:1px solid var(--line);
    border-radius:4px;
    padding:4px;
    background:#fff;
  }

  .wizard-nav{
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-top:48px;
    gap:16px;
  }
  .wizard-nav .spacer{ flex:1; }

  /* ===== success / receipt ===== */
  .success-pane{ display:none; text-align:center; }
  .success-pane.active{ display:block; animation:fadein .6s var(--ease); }
  .success-icon{
    width:84px; height:84px;
    border-radius:50%;
    border:1px solid var(--brass);
    color:var(--brass);
    display:flex; align-items:center; justify-content:center;
    margin:0 auto 28px;
    animation:pop .6s var(--ease);
  }
  @keyframes pop{
    0%{ transform:scale(.6); opacity:0; }
    100%{ transform:scale(1); opacity:1; }
  }
  .receipt{
    text-align:left;
    max-width:480px;
    margin:40px auto 0;
    border:1px dashed var(--line);
    border-radius:4px;
    padding:32px;
    background:var(--ivory);
  }
  .receipt-head{
    text-align:center;
    padding-bottom:22px;
    margin-bottom:22px;
    border-bottom:1px dashed var(--line);
  }
  .receipt-code{
    font-family:var(--serif);
    font-style:italic;
    font-size:30px;
    letter-spacing:0.06em;
    margin-top:6px;
    color:var(--brass);
  }
  .receipt-row{
    display:flex;
    justify-content:space-between;
    gap:14px;
    font-size:14px;
    padding:9px 0;
    color:var(--ink-soft);
  }
  .receipt-row span:last-child{ color:var(--ink); font-weight:600; text-align:right; }
  .receipt-total{
    margin-top:14px;
    padding-top:18px;
    border-top:1px dashed var(--line);
    display:flex;
    justify-content:space-between;
    align-items:baseline;
  }
  .receipt-total .amt{
    font-family:var(--serif);
    font-style:italic;
    font-size:28px;
    color:var(--brass);
  }
  .achv-banner{
    margin:28px auto 0;
    max-width:480px;
    border:1px solid var(--brass);
    border-radius:4px;
    padding:16px 22px;
    font-size:13.5px;
    font-weight:500;
  }
  .achv-link{
    display:inline-block;
    margin-top:18px;
    font-size:12px;
    letter-spacing:0.18em;
    text-transform:uppercase;
    font-weight:500;
    color:var(--brass);
    border-bottom:1px solid var(--brass);
    padding-bottom:2px;
  }

  /* ================= RIWAYAT / ACHIEVEMENT ================= */
  .achv-card{
    border:1px solid var(--line);
    border-radius:4px;
    padding:clamp(24px,4vw,40px);
    margin-bottom:48px;
    background:#fff;
    box-shadow:0 40px 100px -40px rgba(21,19,14,0.18);
  }
  .achv-top{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:24px;
    flex-wrap:wrap;
    margin-bottom:28px;
  }
  .achv-top h3{ margin-top:6px; font-size:clamp(22px,3vw,28px); font-style:italic; }
  .achv-top p{ margin-top:10px; font-size:14px; color:var(--ink-soft); font-weight:300; max-width:380px; }
  .achv-credit{
    text-align:center;
    border:1px solid var(--line);
    border-radius:4px;
    padding:16px 28px;
    flex-shrink:0;
  }
  .achv-credit-num{
    display:block;
    font-family:var(--serif);
    font-style:italic;
    font-size:34px;
    color:var(--brass);
  }
  .achv-credit-lbl{
    display:block;
    margin-top:4px;
    font-size:10.5px;
    letter-spacing:0.16em;
    text-transform:uppercase;
    color:var(--ink-soft);
  }
  .achv-track{
    height:6px;
    background:var(--line-soft);
    border-radius:999px;
    overflow:hidden;
    margin-bottom:14px;
  }
  .achv-fill{
    height:100%;
    background:var(--brass);
    border-radius:999px;
    transition:width .6s var(--ease);
  }
  .achv-dots{
    display:flex;
    gap:10px;
  }
  .achv-dot{
    flex:1;
    display:flex;
    align-items:center;
    justify-content:center;
    height:46px;
    border:1.4px solid var(--line);
    border-radius:4px;
    font-family:var(--serif);
    font-style:italic;
    font-size:16px;
    color:var(--ink-soft);
    transition:all .35s var(--ease);
  }
  .achv-dot.filled{
    background:var(--ink);
    border-color:var(--ink);
    color:var(--brass-soft);
  }
  .achv-dot.gift{ font-size:19px; font-style:normal; }
  .achv-note{
    margin-top:18px;
    font-size:14px;
    color:var(--ink-soft);
  }
  .achv-note b{ color:var(--brass); font-weight:600; }

  .redeem-box{ margin-bottom:30px; }

  /* receipt history */
  .receipt-list{
    display:flex;
    flex-direction:column;
    gap:20px;
  }
  .receipt-card{
    border:1px dashed var(--line);
    border-radius:4px;
    padding:28px clamp(20px,4vw,32px);
    background:var(--ivory);
  }
  .receipt-card-head{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:16px;
    flex-wrap:wrap;
    padding-bottom:18px;
    margin-bottom:18px;
    border-bottom:1px dashed var(--line);
  }
  .receipt-card-code{
    font-family:var(--serif);
    font-style:italic;
    font-size:24px;
    margin-top:4px;
    color:var(--brass);
  }
  .receipt-card-date{
    font-size:12.5px;
    color:var(--ink-soft);
    margin-top:6px;
  }
  .receipt-badges{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
  }
  .receipt-badge{
    font-size:10.5px;
    letter-spacing:0.1em;
    text-transform:uppercase;
    font-weight:600;
    border:1px solid var(--ink);
    border-radius:2px;
    padding:6px 14px;
    white-space:nowrap;
  }
  .receipt-badge.reward{ background:var(--ink); color:var(--brass-soft); }
  .receipt-empty{
    text-align:center;
    padding:64px 24px;
    border:1px dashed var(--line);
    border-radius:4px;
    color:var(--ink-soft);
    font-size:14.5px;
    font-weight:300;
  }
  .receipt-actions{
    margin-top:18px;
    padding-top:18px;
    border-top:1px dashed var(--line);
    text-align:right;
  }

  /* ================= SERVICES SECTION ================= */
  #layanan, #lokasi{
    background:var(--ink);
    color:var(--ivory);
    overflow:hidden;
  }
  .services-grid{
    display:grid;
    grid-template-columns:1fr;
    gap:1px;
    background:var(--line-light);
    border:1px solid var(--line-light);
    border-radius:4px;
    overflow:hidden;
    position:relative;
    z-index:2;
  }
  @media(min-width:760px){ .services-grid{ grid-template-columns:repeat(3,1fr); } }
  .service-tile{
    background:var(--ink);
    padding:46px 36px;
    transition:background .4s var(--ease);
    position:relative;
  }
  .service-tile:hover{ background:rgba(243,239,230,0.04); }
  .service-tile .num{
    font-family:var(--serif);
    font-style:italic;
    color:var(--brass-soft);
    font-size:14px;
  }
  .service-tile h3{
    margin-top:18px;
    font-size:30px;
    font-style:italic;
  }
  .service-tile p{
    margin-top:14px;
    font-size:14.5px;
    color:var(--ink-soft);
    font-weight:300;
  }
  .service-tile .range{
    margin-top:24px;
    display:inline-block;
    font-size:12px;
    letter-spacing:0.12em;
    text-transform:uppercase;
    color:var(--ink-soft);
    border-top:1px solid var(--line-light);
    padding-top:14px;
    width:100%;
  }
  .service-tile .range b{
    display:block;
    margin-top:6px;
    font-family:var(--serif);
    font-style:italic;
    font-weight:600;
    font-size:19px;
    letter-spacing:0;
    text-transform:none;
    color:var(--brass-soft);
  }

  /* location strip inside services or separate */
  .info-strip{
    margin-top:64px;
    display:grid;
    grid-template-columns:1fr;
    gap:1px;
    background:var(--line-light);
    border:1px solid var(--line-light);
    border-radius:4px;
    overflow:hidden;
    position:relative;
    z-index:2;
  }
  @media(min-width:760px){ .info-strip{ grid-template-columns:repeat(auto-fit, minmax(260px, 1fr)); } }
  .info-card{
    background:var(--ink);
    padding:42px 38px;
  }
  .info-card .eyebrow{ margin-bottom:14px; }
  .info-card p{ color:var(--ink-soft); font-size:15px; font-weight:300; }
  .info-card .big{
    font-family:var(--serif);
    font-style:italic;
    font-size:24px;
    margin-top:6px;
    color:var(--brass-soft);
  }

  /* ================= FOOTER ================= */
  footer{
    position:relative;
    background:var(--ink);
    color:var(--ivory);
    padding:90px 0 36px;
    overflow:hidden;
  }
  .footer-grid{
    display:grid;
    grid-template-columns:1fr;
    gap:48px;
    position:relative;
    z-index:2;
  }
  @media(min-width:760px){ .footer-grid{ grid-template-columns:1.3fr 1fr 1fr; } }
  .footer-brand img{ width:64px; height:64px; margin-bottom:22px; filter:brightness(0) invert(1); }
  .footer-brand .l1{
    font-family:var(--serif);
    font-style:italic;
    font-size:24px;
    color:var(--brass-soft);
  }
  .footer-brand .l2{
    font-size:11px;
    letter-spacing:0.32em;
    color:rgba(243,239,230,0.5);
    margin-top:6px;
  }
  .footer-brand p{
    margin-top:22px;
    color:rgba(243,239,230,0.55);
    font-size:14px;
    font-weight:300;
    max-width:300px;
  }
  .footer-col h4{
    font-size:11px;
    letter-spacing:0.28em;
    text-transform:uppercase;
    color:var(--brass-soft);
    margin-bottom:20px;
    font-family:var(--sans);
    font-weight:500;
  }
  .footer-col p, .footer-col li{
    color:rgba(243,239,230,0.7);
    font-size:14.5px;
    font-weight:300;
    line-height:1.9;
    list-style:none;
  }
  .footer-bottom{
    margin-top:80px;
    padding-top:28px;
    border-top:1px solid var(--line-light);
    display:flex;
    flex-wrap:wrap;
    gap:16px;
    justify-content:space-between;
    font-size:12.5px;
    color:rgba(243,239,230,0.4);
    letter-spacing:0.04em;
    position:relative;
    z-index:2;
  }

  /* toast */
  .toast{
    position:fixed;
    bottom:28px;
    left:50%;
    transform:translateX(-50%) translateY(140%);
    background:var(--ink);
    color:var(--ivory);
    border:1px solid var(--brass);
    padding:16px 28px;
    border-radius:2px;
    font-size:13.5px;
    font-weight:500;
    z-index:2000;
    transition:transform .5s var(--ease);
    white-space:nowrap;
  }
  .toast.show{ transform:translateX(-50%) translateY(0); }

  @media(max-width:540px){
    .container{ padding:0 22px; }
    section{ padding:90px 0; }
    .hero{ padding:140px 0 60px; }
  }

  /* ================= NAV AUTH ================= */
  .nav-auth{ display:none; align-items:center; gap:14px; }
  @media(min-width:880px){ .nav-auth{ display:flex; } }
  .nav-auth:empty{ display:none; }
  .nav-auth .user-name{
    font-size:13px;
    color:var(--ivory);
    white-space:nowrap;
  }
  .mobile-nav-auth{
    display:flex;
    flex-direction:column;
    gap:16px;
  }
  .mobile-nav-auth:empty{ display:none; }
  .mobile-nav-auth .user-name{
    font-family:var(--sans);
    font-size:15px;
    font-style:normal;
    letter-spacing:0;
    text-transform:none;
    color:var(--ivory);
  }
  .nav-auth .btn-ghost,
  .mobile-nav-auth .btn-ghost{
    color:var(--ivory);
    border-color:var(--line-light);
  }
  .nav-auth .btn-ghost:hover,
  .mobile-nav-auth .btn-ghost:hover{
    border-color:var(--ivory);
    background:rgba(243,239,230,0.1);
  }
  .mobile-nav-auth .btn-ghost{
    font-family:var(--sans);
    font-style:normal;
    align-self:flex-start;
  }

  /* ================= AUTH PAGES ================= */
  #auth{ padding:170px 0 120px; min-height:80vh; display:flex; align-items:center; }
  .auth-shell{ display:flex; justify-content:center; }
  .auth-card{ max-width:480px; width:100%; }
  .auth-card form{
    display:flex;
    flex-direction:column;
    gap:22px;
    margin-top:32px;
  }
  .auth-switch{
    margin-top:26px;
    font-size:14px;
    color:var(--ink-soft);
    text-align:center;
  }
  .auth-switch a{ color:var(--brass); font-weight:500; }
  .auth-hint{
    margin-top:22px;
    padding:14px 18px;
    border:1px solid var(--line);
    border-radius:4px;
    font-size:12.5px;
    color:var(--ink-soft);
    background:var(--ivory);
    text-align:center;
  }

  /* ================= ADMIN DASHBOARD ================= */
  #admin{ padding-top:160px; }
  .admin-tabs{
    display:flex;
    gap:8px;
    overflow-x:auto;
    margin-bottom:44px;
    border-bottom:1px solid var(--line);
  }
  .admin-tab{
    font-family:var(--sans);
    font-size:11px;
    font-weight:500;
    letter-spacing:0.2em;
    text-transform:uppercase;
    color:var(--ink-soft);
    background:none;
    border:none;
    border-bottom:2px solid transparent;
    padding:16px 14px;
    cursor:pointer;
    white-space:nowrap;
    transition:color .3s var(--ease), border-color .3s var(--ease);
  }
  .admin-tab:hover{ color:var(--ink); }
  .admin-tab.active{ color:var(--brass); border-color:var(--brass); }

  .admin-section{ display:none; }
  .admin-section.active{ display:block; animation:fadein .5s var(--ease); }

  .admin-toolbar{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
    margin-bottom:26px;
    flex-wrap:wrap;
  }
  .admin-toolbar h3{ font-size:clamp(20px, 3vw, 26px); }

  .admin-table{
    display:flex;
    flex-direction:column;
    gap:12px;
  }
  .admin-row{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:20px;
    border:1px solid var(--line);
    border-radius:4px;
    padding:18px 22px;
    flex-wrap:wrap;
    background:#fff;
    transition:border-color .3s var(--ease);
  }
  .admin-row:hover{ border-color:var(--brass-soft); }
  .admin-row-main h4{
    font-style:italic;
    font-size:18px;
    margin-bottom:4px;
  }
  .admin-row-main p{
    font-size:13px;
    color:var(--ink-soft);
  }
  .admin-row-actions{
    display:flex;
    align-items:center;
    gap:10px;
    flex-wrap:wrap;
  }
  .admin-empty{
    text-align:center;
    padding:48px 20px;
    color:var(--ink-soft);
    font-size:14px;
    border:1px dashed var(--line);
    border-radius:4px;
  }

  /* status badge */
  .status-badge{
    display:inline-block;
    font-size:10px;
    letter-spacing:0.18em;
    text-transform:uppercase;
    padding:5px 12px;
    border-radius:2px;
    font-weight:500;
    margin-top:6px;
  }
  .status-badge.pending{ background:var(--ivory-deep); color:var(--ink-soft); }
  .status-badge.confirmed{ background:rgba(179,135,62,0.16); color:var(--brass); }
  .status-badge.done{ background:var(--ink); color:var(--ivory); }
  .status-badge.cancelled{ background:rgba(154,59,44,0.12); color:#9a3b2c; }

  .status-select{
    font-family:var(--sans);
    font-size:12px;
    font-weight:500;
    letter-spacing:0.05em;
    padding:10px 14px;
    border:1px solid var(--line);
    border-radius:4px;
    background:var(--ivory);
    color:var(--ink);
    cursor:pointer;
  }

  /* ================= MODAL ================= */
  .modal-overlay{
    position:fixed;
    inset:0;
    background:rgba(21,19,14,0.55);
    display:flex;
    align-items:center;
    justify-content:center;
    padding:24px;
    z-index:1000;
    opacity:0;
    visibility:hidden;
    transition:opacity .35s var(--ease), visibility .35s var(--ease);
  }
  .modal-overlay.open{ opacity:1; visibility:visible; }
  .modal-box{
    background:#fff;
    border-radius:4px;
    padding:clamp(24px, 5vw, 44px);
    max-width:640px;
    width:100%;
    max-height:88vh;
    overflow-y:auto;
    box-shadow:0 40px 100px -40px rgba(21,19,14,0.4);
    transform:translateY(20px);
    transition:transform .35s var(--ease);
  }
  .modal-overlay.open .modal-box{ transform:translateY(0); }
  .modal-actions{
    display:flex;
    justify-content:flex-end;
    gap:12px;
    margin-top:30px;
  }

  @media(max-width:680px){
    .admin-row{ flex-direction:column; align-items:flex-start; }
    .admin-row-actions{ width:100%; }
  }
