/* ===== Fonts (lokal) ===== */
@font-face{font-family:'Space Grotesk';src:url('assets/fonts/space-grotesk-700.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'Space Grotesk';src:url('assets/fonts/space-grotesk-500.woff2') format('woff2');font-weight:500;font-display:swap}
@font-face{font-family:'Sora';src:url('assets/fonts/sora-600.woff2') format('woff2');font-weight:600;font-display:swap}
@font-face{font-family:'Sora';src:url('assets/fonts/sora-400.woff2') format('woff2');font-weight:400;font-display:swap}

:root{
  --green:#1fae5f; --green-2:#15d67e; --gold:#e7c766; --teal:#19c9b0;
  --ink:#e9f3ee; --muted:#8fab9e;
  --glass:rgba(255,255,255,.055); --glass-2:rgba(255,255,255,.09);
  --brd:rgba(255,255,255,.12); --brd-glow:rgba(31,174,95,.45);
  --display:'Space Grotesk',system-ui,sans-serif;
  --body:'Sora',system-ui,-apple-system,sans-serif;
  --radius:18px;
}
*{box-sizing:border-box}
.hidden{display:none!important}
html{scroll-behavior:smooth}
body{margin:0;color:var(--ink);font-family:var(--body);line-height:1.55;
  background:#03100a;overflow-x:hidden;min-height:100vh}

/* ===== Aurora background ===== */
.aurora{position:fixed;inset:0;z-index:-2;overflow:hidden;
  background:
   radial-gradient(900px 600px at 15% -10%, rgba(20,120,80,.30), transparent 60%),
   radial-gradient(800px 700px at 100% 0%, rgba(20,150,160,.18), transparent 55%),
   linear-gradient(160deg,#03130b 0%,#05190f 45%,#031009 100%)}
.blob{position:absolute;border-radius:50%;filter:blur(90px);opacity:.55;mix-blend-mode:screen}
.blob.b1{width:520px;height:520px;left:-120px;top:-80px;
  background:radial-gradient(circle,#1fae5f,transparent 70%);animation:drift1 18s ease-in-out infinite}
.blob.b2{width:460px;height:460px;right:-100px;top:120px;
  background:radial-gradient(circle,#19c9b0,transparent 70%);animation:drift2 22s ease-in-out infinite}
.blob.b3{width:420px;height:420px;left:40%;bottom:-160px;
  background:radial-gradient(circle,#e7c766,transparent 72%);opacity:.30;animation:drift3 26s ease-in-out infinite}
.grid-overlay{position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);
  background-size:46px 46px;
  -webkit-mask-image:radial-gradient(circle at 50% 30%,#000,transparent 75%);
          mask-image:radial-gradient(circle at 50% 30%,#000,transparent 75%)}
@keyframes drift1{50%{transform:translate(80px,60px) scale(1.1)}}
@keyframes drift2{50%{transform:translate(-70px,40px) scale(1.08)}}
@keyframes drift3{50%{transform:translate(60px,-50px) scale(1.12)}}

/* ===== entrance reveal ===== */
.reveal{opacity:0;transform:translateY(22px);animation:rise .8s cubic-bezier(.2,.7,.2,1) forwards}
.hero.reveal{animation-delay:.08s}
main .input.reveal{animation-delay:.18s}
main .preview.reveal{animation-delay:.28s}
@keyframes rise{to{opacity:1;transform:none}}

/* ===== Header ===== */
.site-header{display:flex;align-items:center;gap:16px;padding:16px 26px;position:sticky;top:0;z-index:20;
  background:rgba(6,22,14,.55);backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid var(--brd)}
.brand{display:flex;align-items:center;gap:14px}
.brand-logo{width:58px;height:58px;object-fit:contain;background:#fff;border-radius:14px;padding:5px;
  box-shadow:0 0 0 1px rgba(255,255,255,.45),0 0 22px rgba(31,174,95,.35),0 6px 16px rgba(0,0,0,.4);
  animation:floaty 5s ease-in-out infinite}
@keyframes floaty{50%{transform:translateY(-5px)}}
.brand-name{font-family:var(--display);font-size:20px;font-weight:700;letter-spacing:.3px;
  background:linear-gradient(90deg,#bff7d6,#e7c766);-webkit-background-clip:text;background-clip:text;color:transparent}
.brand-sub{font-size:12px;color:var(--muted);margin-top:2px}
.header-right{margin-left:auto}
.pill{background:var(--glass);border:1px solid var(--brd);padding:8px 15px;border-radius:999px;font-size:13px;white-space:nowrap}
.pill.secure{box-shadow:0 0 0 0 rgba(31,174,95,.5);animation:pulse 2.6s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(31,174,95,.45)}70%{box-shadow:0 0 0 12px rgba(31,174,95,0)}100%{box-shadow:0 0 0 0 rgba(31,174,95,0)}}

/* ===== Hero ===== */
.hero{text-align:center;padding:46px 20px 10px}
.hero h1{margin:0;font-family:var(--display);font-size:42px;font-weight:700;letter-spacing:-1px;
  background:linear-gradient(100deg,#eafff3 0%,#36e08f 40%,#19c9b0 60%,#e7c766 100%);
  background-size:220% auto;-webkit-background-clip:text;background-clip:text;color:transparent;
  animation:shimmer 7s linear infinite;text-shadow:0 0 40px rgba(31,174,95,.15)}
@keyframes shimmer{to{background-position:220% center}}
.hero p{margin:14px auto 0;max-width:680px;color:var(--muted);font-size:15.5px}
.hero b{color:#bff7d6;font-weight:600}

/* ===== Template picker ===== */
.tpl-bar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;max-width:1280px;margin:14px auto 0;padding:0 24px}
.tpl-bar-label{font-family:var(--display);font-size:13px;color:var(--muted)}
.tpl-picker{display:flex;gap:8px;flex-wrap:wrap}
.tpl-pill{display:flex;align-items:center;gap:8px;font-family:var(--display);font-size:13.5px;font-weight:500;
  padding:9px 16px;border-radius:999px;cursor:pointer;color:var(--ink);
  background:var(--glass);border:1px solid var(--brd);transition:.2s}
.tpl-pill:hover{border-color:var(--green-2)}
.tpl-pill.active{background:linear-gradient(145deg,var(--green-2),var(--green));color:#04120a;
  border-color:transparent;box-shadow:0 4px 16px rgba(31,174,95,.4)}
.tpl-pill .dot{width:7px;height:7px;border-radius:50%;background:var(--gold)}
.tpl-pill.ready .dot{background:#36e08f}
.tpl-notice{max-width:1280px;margin:12px auto 0;padding:11px 18px;border-radius:12px;font-size:13px;
  background:rgba(231,199,102,.12);border:1px solid rgba(231,199,102,.35);color:#f1e2a8}
.tpl-notice.hidden{display:none}
.tpl-notice a{color:#bff7d6;font-weight:600}

/* ===== Layout ===== */
main{display:grid;grid-template-columns:410px 1fr;gap:22px;padding:24px;max-width:1280px;margin:0 auto;align-items:start}
.card{position:relative;background:var(--glass);backdrop-filter:blur(16px) saturate(130%);
  -webkit-backdrop-filter:blur(16px) saturate(130%);
  border:1px solid var(--brd);border-radius:var(--radius);padding:20px;
  box-shadow:0 24px 60px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.06)}
.card::before{content:"";position:absolute;inset:0;border-radius:var(--radius);padding:1px;
  background:linear-gradient(140deg,rgba(31,174,95,.55),transparent 40%,transparent 60%,rgba(231,199,102,.4));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;opacity:.7}
.card-head{display:flex;align-items:center;gap:11px;margin-bottom:16px;padding-bottom:14px;
  border-bottom:1px solid var(--brd)}
.card-head .ic{width:36px;height:36px;display:grid;place-items:center;border-radius:11px;font-size:17px;
  background:linear-gradient(145deg,rgba(31,174,95,.25),rgba(25,201,176,.12));
  border:1px solid var(--brd);box-shadow:0 0 18px rgba(31,174,95,.25)}
.card-head h2{margin:0;font-family:var(--display);font-size:16px;font-weight:700;color:#eafff3}
.card-head .nav{margin-left:auto;display:flex;align-items:center;gap:7px}

/* ===== Tabs ===== */
.tabs{display:flex;gap:6px;background:rgba(0,0,0,.25);padding:5px;border-radius:13px;margin-bottom:14px;border:1px solid var(--brd)}
.tab{flex:1;padding:10px;border:none;background:transparent;border-radius:9px;cursor:pointer;
  font-family:var(--display);font-size:13.5px;font-weight:500;color:var(--muted);transition:.2s}
.tab:hover{color:var(--ink)}
.tab.active{color:#04120a;background:linear-gradient(145deg,var(--green-2),var(--green));
  box-shadow:0 4px 16px rgba(31,174,95,.45)}
.tabpane.hidden{display:none}
.tabpane{animation:rise .4s ease}

/* ===== form / file ===== */
.hint{font-size:12.5px;color:var(--muted);margin:6px 0}
.center{text-align:center}
.file-drop{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px;cursor:pointer;
  border:1.5px dashed rgba(31,174,95,.45);border-radius:14px;color:#bff7d6;font-size:13.5px;font-weight:500;
  background:rgba(31,174,95,.06);transition:.25s}
.file-drop:hover{border-color:var(--green-2);background:rgba(31,174,95,.13);box-shadow:0 0 26px rgba(31,174,95,.25) inset}
.file-drop .fd-ic{font-size:26px;filter:drop-shadow(0 0 8px rgba(31,174,95,.6))}
#manualForm{display:grid;gap:10px;margin:8px 0 12px}
.fld{display:grid;gap:4px}
.fld label{font-size:11.5px;color:var(--muted);font-weight:500;font-family:var(--display)}
.fld input{padding:9px 11px;border:1px solid var(--brd);border-radius:10px;font-size:13.5px;font-family:var(--body);
  background:rgba(0,0,0,.28);color:var(--ink);transition:.2s}
.fld input::placeholder{color:#5e7468}
.fld input:focus{outline:none;border-color:var(--green-2);
  box-shadow:0 0 0 3px rgba(31,174,95,.18),0 0 18px rgba(31,174,95,.25)}
.fld.const input{background:rgba(231,199,102,.06);border-color:rgba(231,199,102,.22)}

/* ===== buttons ===== */
.btn{position:relative;overflow:hidden;font-family:var(--display);font-weight:500;border-radius:11px;cursor:pointer;
  font-size:13px;padding:10px 15px;border:1px solid transparent;transition:.2s}
.btn.sm{padding:8px 13px;font-size:12.5px}.btn.xs{padding:7px 10px;font-size:12px}
.btn.primary{color:#04120a;background:linear-gradient(145deg,var(--green-2),var(--green));
  box-shadow:0 6px 20px rgba(31,174,95,.4)}
.btn.primary:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(31,174,95,.55)}
.btn.primary::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(110deg,transparent,rgba(255,255,255,.55),transparent);transform:skewX(-20deg)}
.btn.primary:hover::after{animation:shine .8s}
@keyframes shine{to{left:140%}}
.btn.ghost{background:var(--glass-2);border-color:var(--brd);color:var(--ink)}
.btn.ghost:hover{border-color:var(--green-2);color:#bff7d6;box-shadow:0 0 16px rgba(31,174,95,.2)}
.btn:disabled{opacity:.38;cursor:not-allowed;transform:none;box-shadow:none}
.btn:disabled::after{display:none}
#sampleXlsx{margin-top:11px}

/* ===== status / chips ===== */
.status{font-size:13px;margin-top:11px;min-height:18px}
.status.ok{color:var(--green-2);font-weight:600} .status.err{color:#ff7a7a;font-weight:600}
.chip{background:rgba(31,174,95,.14);color:#bff7d6;font-size:12px;font-weight:600;font-family:var(--display);
  padding:4px 11px;border-radius:999px;border:1px solid rgba(31,174,95,.3)}
.muted{color:var(--muted)}

/* ===== records ===== */
.records{margin-top:18px;border-top:1px solid var(--brd);padding-top:14px}
.records-head{display:flex;align-items:center;gap:8px}
.records-head .btn{margin-left:auto}
#recordList{margin:11px 0 0;padding:0;list-style:none;max-height:200px;overflow:auto}
#recordList li{display:flex;align-items:center;gap:9px;padding:9px 11px;border-radius:10px;font-size:13.5px;
  cursor:pointer;border:1px solid transparent;transition:.18s}
#recordList li:before{content:"👤";font-size:13px;opacity:.6}
#recordList li:hover{background:var(--glass-2)}
#recordList li.active{background:linear-gradient(145deg,rgba(31,174,95,.20),rgba(25,201,176,.08));
  border-color:rgba(31,174,95,.4);font-weight:600;color:#eafff3;box-shadow:0 0 18px rgba(31,174,95,.2)}
#recordList li.active:before{content:"📄";opacity:1}

/* ===== advanced ===== */
.adv{margin-top:16px;font-size:13px;border-top:1px solid var(--brd);padding-top:12px}
.adv summary{cursor:pointer;color:var(--muted);font-weight:500;font-family:var(--display)}
.adv summary:hover{color:var(--ink)}
.adv .row{display:grid;gap:6px;margin-top:11px}
.adv input[type=file]{font-size:12.5px;color:var(--muted)}

/* ===== toolbar ===== */
.toolbar{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:16px}

/* ===== edit panel (front-page editing) ===== */
.edit-panel{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:12px;padding:10px 12px;
  background:rgba(0,0,0,.28);border:1px solid var(--brd);border-radius:12px}
.edit-panel.hidden{display:none}
.ep-name{font-family:var(--display);font-size:12.5px;color:#bff7d6;min-width:90px}
.ep-group{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.edit-panel select,.edit-panel input[type=number]{background:rgba(0,0,0,.3);color:var(--ink);
  border:1px solid var(--brd);border-radius:7px;padding:5px 7px;font-size:12.5px}
.edit-panel input[type=number]{width:56px}
.edit-panel input[type=color]{width:30px;height:30px;border:1px solid var(--brd);border-radius:7px;background:none;padding:0;cursor:pointer}
.tgmini{width:30px;height:30px;border:1px solid var(--brd);background:var(--glass-2);color:var(--ink);
  border-radius:7px;cursor:pointer;font-size:13px;display:grid;place-items:center}
.tgmini:hover{border-color:var(--green-2)}
.tgmini.on{background:linear-gradient(145deg,var(--green-2),var(--green));color:#04120a;border-color:transparent}
.ep-pos{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--muted)}
.a4 .t.editable{cursor:grab}
.a4 .t.editable:hover{outline:1px solid rgba(31,140,200,.6);outline-offset:1px}
.a4 .t.sel-edit{outline:2px solid #1f8fd0;outline-offset:1px;background:rgba(31,140,200,.08)}

/* ===== preview stage ===== */
.stage{background:radial-gradient(circle at 50% 20%,rgba(31,174,95,.10),transparent 60%),rgba(0,0,0,.30);
  border:1px solid var(--brd);border-radius:14px;padding:22px;display:flex;justify-content:center;overflow:auto}
.a4{position:relative;width:793.7px;height:1122.5px;background:#fff;transform-origin:top center;border-radius:3px;
  box-shadow:0 0 0 1px rgba(255,255,255,.4),0 0 70px rgba(31,174,95,.18),0 30px 60px rgba(0,0,0,.55)}
.a4 .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:fill;opacity:.92}
.a4 .t{position:absolute;white-space:nowrap;line-height:1;color:#000}

/* ===== footer ===== */
.site-footer{display:flex;align-items:center;gap:18px;flex-wrap:wrap;padding:26px 30px;margin-top:24px;
  font-size:13px;background:rgba(4,16,10,.6);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-top:1px solid var(--brd)}
.foot-logo{width:50px;height:50px;object-fit:contain;background:#fff;border-radius:12px;padding:4px}
.site-footer b{font-family:var(--display);color:#eafff3}
.site-footer .muted{color:var(--muted)}
.foot-badge{margin-left:auto;background:var(--glass);border:1px solid var(--brd);
  padding:9px 15px;border-radius:999px;white-space:nowrap;color:#bff7d6}

/* ===== scrollbars ===== */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:rgba(31,174,95,.4);border-radius:10px;border:2px solid transparent;background-clip:content-box}
::-webkit-scrollbar-thumb:hover{background:rgba(31,174,95,.6);background-clip:content-box}
::-webkit-scrollbar-track{background:transparent}

@media(max-width:920px){
  main{grid-template-columns:1fr}
  .hero h1{font-size:30px}
  .brand-sub{display:none}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important}
  .reveal{opacity:1;transform:none}
}
/* Saat dicetak dari browser: background blangko TIDAK ikut tercetak */
@media print{
  .a4 .bg,.ed-bg{display:none!important}
}
