:root{
  --bg:#fff8f2;
  --surface:#ffffff;
  --surface-2:#fff2fb;
  --text:#2c2340;
  --muted:#7f7196;
  --line:rgba(100,80,130,.12);
  --orange:#ff8a1f;
  --orange-deep:#ff6a00;
  --purple:#7b45ff;
  --purple-deep:#5925d9;
  --success:#15a36e;
  --warning:#ffb020;
  --danger:#eb5757;
  --shadow:0 14px 34px rgba(98,52,183,.12);
  --radius:24px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:linear-gradient(180deg,#fff8f2 0%, #fff7ff 50%, #fff 100%);color:var(--text);font-family:Inter,Arial,Helvetica,sans-serif;overflow-x:hidden}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font:inherit}
body{min-height:100vh}
.hidden{display:none!important}

.auth-body{display:flex;align-items:center;justify-content:center;padding:20px}
.auth-wrap{width:100%;max-width:480px}
.auth-card{background:rgba(255,255,255,.92);backdrop-filter: blur(14px);border:1px solid rgba(255,255,255,.7);box-shadow:var(--shadow);border-radius:32px;padding:24px;position:relative;overflow:hidden}
.auth-card:before,.auth-card:after{content:"";position:absolute;border-radius:999px;filter:blur(8px);opacity:.3;z-index:0}
.auth-card:before{width:180px;height:180px;background:linear-gradient(135deg,var(--orange),transparent);top:-50px;right:-50px}
.auth-card:after{width:140px;height:140px;background:linear-gradient(135deg,var(--purple),transparent);bottom:-40px;left:-30px}
.auth-card>*{position:relative;z-index:1}
.eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.16em;color:var(--orange-deep);font-weight:800;margin-bottom:8px}
.auth-card h1{margin:0 0 10px;font-size:28px;line-height:1.18}
.auth-sub{color:var(--muted);font-size:14px;line-height:1.6;margin:0 0 18px}
.glass-panel{background:linear-gradient(135deg,rgba(255,255,255,.85),rgba(255,244,255,.9));border:1px solid var(--line);border-radius:24px;padding:16px}
.auth-hero{margin-bottom:18px}
.chip{display:inline-flex;padding:8px 12px;border-radius:999px;font-size:12px;font-weight:700;margin-right:8px;margin-bottom:10px}
.chip.orange{background:rgba(255,138,31,.12);color:var(--orange-deep)}
.chip.purple{background:rgba(123,69,255,.12);color:var(--purple-deep)}
.hero-mini-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:8px}
.mini-stat{background:#fff;border:1px solid var(--line);border-radius:18px;padding:12px}
.mini-stat strong{display:block;font-size:16px}
.mini-stat span{color:var(--muted);font-size:12px}
.big-login-btn{width:100%;display:flex;gap:14px;align-items:flex-start;border:none;border-radius:24px;padding:18px;margin-top:14px;box-shadow:var(--shadow);cursor:pointer;transform:translateY(0);transition:.2s ease;min-height:82px;text-align:left}
.big-login-btn:active{transform:scale(.98)}
.big-login-btn .icon{font-size:24px;line-height:1.3}
.big-login-btn strong{display:block;font-size:15px;margin-bottom:4px}
.big-login-btn small{display:block;color:rgba(255,255,255,.88);font-size:12px;line-height:1.5}
.admin-btn{background:linear-gradient(135deg,var(--purple),#9d74ff);color:#fff}
.user-btn{background:linear-gradient(135deg,var(--orange),#ffab3d);color:#fff}
.auth-footer{margin-top:20px;display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;color:var(--muted);font-size:12px}

.app-body{padding:0;margin:0}
.mobile-shell{width:100%;max-width:520px;margin:0 auto;background:linear-gradient(180deg,#fff8f2 0%, #fff 100%);min-height:100vh;position:relative;overflow-x:hidden}
.screen-content{padding:16px 16px 28px}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:16px;gap:12px;background:rgba(255,255,255,.85);backdrop-filter:blur(10px);border-bottom:1px solid rgba(120,70,170,.08)}
.sticky{position:sticky;top:0;z-index:40}
.topbar-title{margin:3px 0 0;font-size:18px;line-height:1.25}
.topbar-actions{display:flex;gap:8px}
.icon-btn{border:none;background:#fff;box-shadow:0 10px 20px rgba(70,40,120,.08);width:42px;height:42px;border-radius:14px;font-size:18px;cursor:pointer}
.card{background:var(--surface);border:1px solid var(--line);border-radius:24px;padding:16px;box-shadow:var(--shadow)}
.card-title{margin:0 0 8px;font-size:16px}
.card-sub{color:var(--muted);font-size:13px;line-height:1.55}
.grid-2,.grid-3,.grid-4{display:grid;gap:14px}
.grid-2{grid-template-columns:1fr 1fr}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.summary-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.summary-card{background:linear-gradient(180deg,#fff,#fff5fb);border:1px solid var(--line);border-radius:20px;padding:14px}
.summary-card strong{display:block;font-size:22px;margin-bottom:6px}
.summary-card span{display:block;color:var(--muted);font-size:12px}
.hero-gradient{background:linear-gradient(135deg,rgba(123,69,255,.98),rgba(255,138,31,.95));color:#fff;border:none}
.hero-gradient .card-sub{color:rgba(255,255,255,.85)}
.status-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.badge{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;font-size:12px;font-weight:700}
.badge.orange{background:rgba(255,138,31,.14);color:var(--orange-deep)}
.badge.purple{background:rgba(123,69,255,.14);color:var(--purple-deep)}
.badge.green{background:rgba(21,163,110,.14);color:var(--success)}
.badge.red{background:rgba(235,87,87,.14);color:var(--danger)}
.badge.gray{background:rgba(120,120,140,.12);color:#6a627c}
.quick-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.quick-item{background:#fff;border:1px solid var(--line);border-radius:22px;padding:14px 8px;text-align:center;cursor:pointer;transition:.2s ease;box-shadow:0 10px 22px rgba(76,53,140,.06)}
.quick-item:active{transform:scale(.97)}
.quick-item .qi-icon{font-size:22px;display:block;margin-bottom:8px}
.quick-item span{font-size:12px;font-weight:700;line-height:1.3}
.banner-slider{display:flex;gap:12px;overflow:auto;padding-bottom:2px;scrollbar-width:none}
.banner-slider::-webkit-scrollbar{display:none}
.banner-card{min-width:250px;background:linear-gradient(135deg,#fff5e8,#f7f1ff);border:1px solid var(--line);border-radius:22px;padding:16px;box-shadow:var(--shadow)}
.list-card{display:flex;gap:12px;align-items:flex-start;padding:14px;border-radius:20px;background:#fff;border:1px solid var(--line);margin-bottom:12px;box-shadow:0 8px 18px rgba(76,53,140,.05)}
.list-icon{width:44px;height:44px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(255,138,31,.18),rgba(123,69,255,.18));font-size:20px;flex:0 0 44px}
.list-content{flex:1;min-width:0}
.list-content strong{display:block;font-size:14px;margin-bottom:4px}
.list-content p{margin:0;color:var(--muted);font-size:12px;line-height:1.55}
.list-meta{font-size:11px;color:var(--muted);margin-top:8px;display:flex;gap:8px;flex-wrap:wrap}
.section-title{margin:0 0 12px;font-size:17px}
.section-block{margin-bottom:18px}
.progress-track{height:10px;background:#f3ecff;border-radius:999px;overflow:hidden;margin-top:10px}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--orange),var(--purple));border-radius:999px;animation:grow 1s ease}
@keyframes grow{from{width:0}to{width:var(--w)}}
.table-list{display:grid;gap:10px}
.row-card{padding:14px;border:1px solid var(--line);border-radius:18px;background:#fff}
.row-top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.row-top strong{font-size:14px}
.row-bottom{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px;color:var(--muted);font-size:12px}
.metric-strip{display:flex;gap:10px;overflow:auto;padding-bottom:2px;scrollbar-width:none}
.metric-card{min-width:145px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:14px;box-shadow:0 10px 24px rgba(82,49,140,.06)}
.metric-card strong{font-size:20px;display:block}
.metric-card span{font-size:12px;color:var(--muted)}
.analytics-grid{display:grid;grid-template-columns:1fr;gap:14px}
.chart-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:16px;box-shadow:var(--shadow)}
.bar-chart{display:flex;align-items:flex-end;gap:10px;height:180px;margin-top:16px}
.bar-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:8px;min-width:0}
.bar{width:100%;max-width:34px;border-radius:14px 14px 8px 8px;background:linear-gradient(180deg,var(--orange),var(--purple));min-height:8px;transition:.35s ease}
.bar-label{font-size:11px;color:var(--muted)}
.bar-value{font-size:11px;font-weight:700}
.drawer{position:fixed;inset:0;background:rgba(35,24,52,.25);z-index:70;display:none}
.drawer.open{display:block}
.drawer-card{position:absolute;left:0;top:0;bottom:0;width:min(84vw,320px);background:#fff;border-radius:0 26px 26px 0;padding:16px;box-shadow:0 30px 60px rgba(44,24,90,.18);animation:slideIn .22s ease}
@keyframes slideIn{from{transform:translateX(-16px);opacity:0}to{transform:none;opacity:1}}
.drawer-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:14px}
.avatar-circle{width:54px;height:54px;border-radius:18px;background:linear-gradient(135deg,var(--orange),var(--purple));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:18px;margin-bottom:10px}
.drawer-head p{margin:4px 0 0;color:var(--muted);font-size:12px}
.drawer-nav{display:grid;gap:8px}
.drawer-nav button{border:none;background:#fff7fb;border:1px solid var(--line);padding:14px;border-radius:16px;text-align:left;font-weight:700;cursor:pointer}
.modal{position:fixed;inset:0;background:rgba(32,18,49,.32);display:flex;align-items:flex-end;justify-content:center;padding:12px;z-index:90}
.modal .modal-card{width:100%;max-width:520px;background:#fff;border-radius:28px 28px 18px 18px;padding:18px;box-shadow:0 30px 60px rgba(44,24,90,.2);animation:up .2s ease}
@keyframes up{from{transform:translateY(18px);opacity:0}to{transform:none;opacity:1}}
.form-group{margin-bottom:12px}
.label{display:block;font-weight:700;font-size:13px;margin-bottom:7px}
.input,.select,.textarea{width:100%;border:1px solid var(--line);background:#fff;border-radius:16px;padding:13px 14px;outline:none}
.textarea{min-height:96px;resize:vertical}
.btn-row{display:flex;gap:10px;margin-top:14px}
.btn{flex:1;border:none;border-radius:16px;padding:14px 16px;font-weight:800;cursor:pointer}
.btn.primary{background:linear-gradient(135deg,var(--orange),var(--purple));color:#fff}
.btn.soft{background:#fff7fb;color:var(--purple-deep);border:1px solid var(--line)}
.bottom-nav{position:fixed;left:50%;transform:translateX(-50%);bottom:0;width:100%;max-width:520px;display:grid;grid-template-columns:repeat(5,1fr);gap:8px;padding:10px 12px calc(10px + env(safe-area-inset-bottom));background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-top:1px solid var(--line);z-index:50}
.bottom-nav button{border:none;background:transparent;padding:8px 6px;border-radius:16px;font-size:11px;font-weight:700;color:var(--muted);cursor:pointer}
.bottom-nav button.active{background:#fff5fb;color:var(--purple-deep)}
.bottom-nav .nav-ico{display:block;font-size:18px;margin-bottom:4px}
.bottom-padding{padding-bottom:94px}
.toast{position:fixed;left:50%;transform:translateX(-50%) translateY(120px);bottom:20px;background:#2d2142;color:#fff;padding:12px 16px;border-radius:999px;box-shadow:0 14px 34px rgba(22,10,44,.24);font-size:13px;z-index:120;opacity:0;transition:.25s ease;pointer-events:none;max-width:90vw;text-align:center}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}
.skeleton-card-grid{display:grid;gap:14px}
.skeleton-card{height:120px;border-radius:24px;background:linear-gradient(90deg,#fff,#fff7fb,#fff);background-size:200% 100%;animation:shimmer 1.3s linear infinite;border:1px solid var(--line)}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.fade-in{animation:fade .45s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.inline-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.small-btn{border:none;background:#fff7fb;color:var(--purple-deep);padding:10px 12px;border-radius:14px;font-weight:700;font-size:12px;cursor:pointer;border:1px solid var(--line)}
.kv{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}
.kv div{background:#fff7fb;border-radius:16px;padding:12px;font-size:12px}
.kv strong{display:block;color:var(--text);margin-bottom:4px}

@media (min-width: 720px){
  .mobile-shell{max-width:1180px}
  .screen-content{padding:22px 22px 32px}
  .analytics-grid{grid-template-columns:1fr 1fr}
  .summary-grid{grid-template-columns:repeat(5,1fr)}
  .quick-grid{grid-template-columns:repeat(6,1fr)}
  .bottom-nav{position:sticky;transform:none;left:auto;max-width:none;border-radius:22px;margin:0 20px 14px;bottom:14px;box-shadow:var(--shadow)}
  .bottom-padding{padding-bottom:28px}
}

@media (max-width: 420px){
  .grid-2,.summary-grid,.hero-mini-grid{grid-template-columns:1fr}
  .quick-grid{grid-template-columns:repeat(3,1fr)}
  .row-bottom,.kv{grid-template-columns:1fr}
  .auth-card h1{font-size:24px}
}

.auth-form-box,.auth-info-box{margin-top:14px}.auth-demo-list{display:grid;gap:8px;margin-top:10px;color:#5d4c70}.big-login-btn.compact{margin-top:14px}.small-btn.danger{background:#fff1f1;color:#c23b4d;border:1px solid #ffd2d8}.inline-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.modal-card textarea,.modal-card input,.modal-card select{width:100%}

.package-image{width:100%;border-radius:20px;overflow:hidden;border:1px solid var(--line);background:linear-gradient(135deg,#fff8ed,#f7f0ff);margin-bottom:12px;display:flex;align-items:center;justify-content:center;min-height:180px}
.package-image.compact{min-height:160px}
.package-image img{display:block;width:100%;height:220px;object-fit:cover}
.package-image.compact img{height:170px}
.package-image.placeholder{flex-direction:column;gap:8px;color:#8d6aa8;font-weight:700}
.package-image.placeholder span{font-size:34px}
.btn.secondary{background:#f5efff;color:var(--purple-deep);border:1px solid #eadcff}


/* ==== polished form experience ==== */
.auth-form-box,.auth-info-box{
  border-radius:26px;
  box-shadow:0 18px 40px rgba(95,57,170,.08);
}
.auth-form-box{
  background:linear-gradient(180deg,#ffffff 0%,#fff8fd 100%);
  border:1px solid rgba(123,69,255,.10);
  padding:18px;
}
.auth-form-box label{
  display:block;
  font-size:13px;
  font-weight:800;
  color:#5a476f;
  margin:0 0 8px;
}
.auth-form-box input{
  width:100%;
  height:52px;
  border-radius:16px;
  border:1px solid rgba(123,69,255,.16);
  background:linear-gradient(180deg,#fff,#fffafc);
  padding:0 16px;
  margin:0 0 14px;
  font-size:16px;
  color:var(--text);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9),0 8px 18px rgba(92,58,156,.04);
  transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}
.auth-form-box input:focus{
  border-color:rgba(123,69,255,.45);
  box-shadow:0 0 0 4px rgba(123,69,255,.12), inset 0 1px 0 rgba(255,255,255,.9);
  outline:none;
}
.auth-info-box{
  background:linear-gradient(180deg,#fff,#fffaf6);
}
.auth-demo-list div{
  padding:10px 12px;
  border-radius:16px;
  border:1px solid rgba(123,69,255,.08);
  background:#fff;
}
.modal{
  backdrop-filter:blur(7px);
  -webkit-backdrop-filter:blur(7px);
}
.modal .modal-card{
  width:100%;
  max-width:560px;
  max-height:min(90vh,860px);
  overflow-y:auto;
  background:linear-gradient(180deg,#ffffff 0%,#fff9fd 100%);
  border:1px solid rgba(123,69,255,.12);
  border-radius:32px 32px 22px 22px;
  padding:20px;
  box-shadow:0 30px 60px rgba(44,24,90,.22);
  position:relative;
}
.modal .modal-card::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:88px;
  border-radius:32px 32px 0 0;
  background:linear-gradient(135deg,rgba(255,138,31,.10),rgba(123,69,255,.12));
  pointer-events:none;
}
.modal .modal-card > *{position:relative;z-index:1}
.modal .row-top{
  position:sticky;
  top:-20px;
  z-index:2;
  margin:-20px -20px 16px;
  padding:18px 20px 14px;
  background:linear-gradient(180deg,rgba(255,255,255,.97),rgba(255,250,253,.94));
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(123,69,255,.08);
}
.modal .row-top strong{
  font-size:22px;
  line-height:1.2;
  color:#34254b;
  letter-spacing:-.02em;
}
.modal .icon-btn{
  flex:0 0 48px;
  width:48px;
  height:48px;
  border-radius:16px;
  background:linear-gradient(180deg,#fff,#fff7fb);
  border:1px solid rgba(123,69,255,.10);
  box-shadow:0 10px 24px rgba(92,58,156,.08);
}
.modal .icon-btn:hover{transform:translateY(-1px)}
.modal .icon-btn:active{transform:scale(.97)}
.modal-card label{
  display:block;
  margin:14px 0 8px;
  font-size:13px;
  font-weight:800;
  letter-spacing:.01em;
  color:#59496d;
}
.modal-card input,
.modal-card select,
.modal-card textarea{
  width:100%;
  min-height:52px;
  border-radius:16px;
  border:1px solid rgba(123,69,255,.15);
  background:linear-gradient(180deg,#ffffff 0%,#fff9fd 100%);
  padding:12px 14px;
  font-size:15px;
  color:#2f2441;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.95),0 8px 18px rgba(92,58,156,.04);
  transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease, background .2s ease;
  appearance:none;
  -webkit-appearance:none;
}
.modal-card textarea{
  min-height:110px;
  resize:vertical;
  line-height:1.55;
}
.modal-card select{
  padding-right:42px;
  background-image:linear-gradient(45deg,transparent 50%,rgba(89,73,109,.8) 50%),linear-gradient(135deg,rgba(89,73,109,.8) 50%,transparent 50%),linear-gradient(180deg,#ffffff 0%,#fff9fd 100%);
  background-position:calc(100% - 20px) calc(50% - 3px),calc(100% - 14px) calc(50% - 3px),0 0;
  background-size:6px 6px,6px 6px,100% 100%;
  background-repeat:no-repeat;
}
.modal-card input[type="date"]{
  padding-right:14px;
}
.modal-card input[type="file"]{
  min-height:54px;
  padding:10px 12px;
  background:#fff;
}
.modal-card input[type="file"]::file-selector-button{
  border:none;
  border-radius:12px;
  padding:10px 14px;
  margin-right:12px;
  font-weight:800;
  color:#fff;
  background:linear-gradient(135deg,var(--orange),var(--purple));
  cursor:pointer;
}
.modal-card input:focus,
.modal-card select:focus,
.modal-card textarea:focus{
  outline:none;
  border-color:rgba(123,69,255,.42);
  box-shadow:0 0 0 4px rgba(123,69,255,.11), inset 0 1px 0 rgba(255,255,255,.95);
  background:#fff;
}
.modal-card ::placeholder{color:#b09abc}
.btn-row{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:12px;
  margin-top:20px;
}
.btn{
  min-height:54px;
  border-radius:18px;
  font-size:15px;
  box-shadow:0 12px 26px rgba(92,58,156,.10);
  transition:transform .2s ease, box-shadow .2s ease, opacity .2s ease;
}
.btn:hover{transform:translateY(-1px);box-shadow:0 16px 32px rgba(92,58,156,.13)}
.btn:active{transform:scale(.98)}
.btn.soft{background:linear-gradient(180deg,#fff,#fff5fb)}
.btn.secondary{background:linear-gradient(180deg,#f7f2ff,#efe5ff)}
.package-image{
  border-radius:22px;
  box-shadow:0 16px 34px rgba(92,58,156,.10);
}
.row-card{
  box-shadow:0 12px 24px rgba(92,58,156,.05);
}
.small-btn{
  min-height:40px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
@media (min-width:721px){
  .modal{align-items:center;padding:20px}
  .modal .modal-card{border-radius:30px;}
}
@media (max-width:520px){
  .modal{padding:10px}
  .modal .modal-card{padding:18px 16px 16px;border-radius:28px 28px 20px 20px}
  .modal .row-top{top:-18px;margin:-18px -16px 14px;padding:16px}
  .modal .row-top strong{font-size:20px}
  .btn-row{grid-template-columns:1fr}
}

.public-cta-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.public-cta-btn{flex:1;min-width:140px;display:inline-flex;justify-content:center;align-items:center;padding:12px 14px;border-radius:18px;background:linear-gradient(135deg,var(--orange),var(--purple));color:#fff;font-weight:800;box-shadow:var(--shadow)}
.public-cta-btn.soft{background:#fff;color:var(--purple-deep);border:1px solid var(--line)}
.file-link{color:var(--purple-deep);font-weight:700;word-break:break-all}
.filter-box{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}.filter-box input{flex:1;min-width:180px}
.modal-card label{display:block;font-size:13px;font-weight:800;color:#5a476f;margin:10px 0 8px}
.modal-card input,.modal-card select,.modal-card textarea{width:100%;min-height:48px;border-radius:16px;border:1px solid rgba(123,69,255,.16);background:linear-gradient(180deg,#fff,#fffafc);padding:12px 14px;box-shadow:inset 0 1px 0 rgba(255,255,255,.9),0 8px 18px rgba(92,58,156,.04)}
.modal-card textarea{min-height:96px;resize:vertical}
.modal-card input:focus,.modal-card select:focus,.modal-card textarea:focus{border-color:rgba(123,69,255,.45);box-shadow:0 0 0 4px rgba(123,69,255,.12), inset 0 1px 0 rgba(255,255,255,.9);outline:none}
.doc-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.doc-grid-2>div{background:#fff8fc;border:1px solid var(--line);padding:12px;border-radius:18px}
@media(max-width:560px){.doc-grid-2{grid-template-columns:1fr}}

.soft-surface{background:linear-gradient(180deg,#fff,#fff8fd);border:1px solid rgba(123,69,255,.12)}
.mini-stack{display:grid;gap:8px}
.mini-item{padding:10px 12px;border-radius:14px;background:#fff;border:1px solid var(--line);font-size:13px;color:#5a476f}
.doc-preview-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(82px,1fr));gap:10px;margin-bottom:10px}
.doc-mini{display:flex;flex-direction:column;gap:6px;align-items:center;text-align:center;font-size:12px;color:#5e4a72}
.doc-thumb{width:100%;aspect-ratio:1/1;border-radius:16px;overflow:hidden;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 18px rgba(92,58,156,.05)}
.doc-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.doc-thumb.placeholder{font-weight:700;color:#8a74a4;padding:8px}
.doc-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:14px}
.doc-slot-card{display:grid;grid-template-columns:110px 1fr;gap:14px;padding:14px;border-radius:22px;background:linear-gradient(180deg,#fff,#fff9fd);border:1px solid rgba(123,69,255,.12);box-shadow:0 12px 24px rgba(92,58,156,.06)}
.doc-slot-body{display:grid;gap:10px}
.doc-meta{display:grid;gap:6px;font-size:13px;color:#655277}
.preview-wrap{background:#fff;border:1px solid var(--line);border-radius:22px;overflow:hidden;max-height:70vh;display:flex;justify-content:center;align-items:center}
.preview-image{display:block;max-width:100%;max-height:70vh;object-fit:contain}
.preview-frame{width:100%;height:70vh;border:none;border-radius:18px;background:#fff}
.modal-card.modal-lg{max-width:980px}
@media(max-width:640px){.doc-slot-card{grid-template-columns:1fr}.modal-card.modal-lg{max-width:none}}

.brand-logo-wrap{margin-bottom:12px;display:flex;justify-content:flex-start}.brand-logo{width:74px;height:74px;object-fit:contain;border-radius:18px;background:#fff;padding:10px;box-shadow:0 14px 34px rgba(123,69,255,.18)}
.settings-grid{display:grid;grid-template-columns:1fr;gap:16px}.upload-setting-card{padding:14px;border:1px solid rgba(120,70,170,.12);border-radius:18px;background:#fff7ff;margin-bottom:12px}.upload-setting-card img{width:100%;max-height:120px;object-fit:contain;border-radius:14px;background:#fff}.upload-setting-card .mini{font-size:12px;color:#7a6b93;margin-top:6px}.doc-grid{display:grid;grid-template-columns:1fr;gap:12px}.doc-slot-card{display:grid;grid-template-columns:92px 1fr;gap:12px;padding:12px;border:1px solid rgba(120,70,170,.12);border-radius:18px;background:#fff}.doc-thumb{width:92px;height:92px;border-radius:16px;overflow:hidden;background:#f4f1fb;display:flex;align-items:center;justify-content:center}.doc-thumb img{width:100%;height:100%;object-fit:cover}.doc-thumb.placeholder{font-weight:700;color:#8d7bb0}.doc-slot-body{display:flex;flex-direction:column;gap:8px}.doc-meta{font-size:13px;color:#705f8e;display:grid;gap:4px}.preview-wrap{display:flex;justify-content:center;padding:10px 0}.preview-image{max-width:100%;max-height:70vh;border-radius:18px}.preview-frame{width:100%;height:70vh;border:none;border-radius:18px;background:#fff}.modal-lg{max-width:900px}.info-kv{display:grid;grid-template-columns:1fr;gap:8px;margin:10px 0 0}.info-kv .kv{padding:10px 12px;border-radius:14px;background:#f8f5ff;border:1px solid rgba(120,70,170,.08)}
@media(min-width:860px){.settings-grid{grid-template-columns:1.1fr .9fr}.doc-grid{grid-template-columns:1fr 1fr}}


/* PATCH V14 */
.empty-state{padding:24px;text-align:center;color:#6d6490}
.cabang-hero{padding:18px}
.file-link{color:#7b45ff;text-decoration:none;font-weight:700;word-break:break-all}
.file-link:hover{text-decoration:underline}
.topbar-title small{display:block;font-size:12px;color:#8a7fb0}
.doc-grid,.doc-grid-2{display:grid;gap:14px}
.doc-grid{grid-template-columns:1fr}
.doc-grid-2{grid-template-columns:1fr 1fr}
.doc-slot-card{display:grid;grid-template-columns:84px 1fr;gap:12px;padding:12px;border:1px solid #ebe3ff;border-radius:18px;background:#fff}
.doc-thumb{width:84px;height:84px;border-radius:14px;overflow:hidden;background:#f8f5ff;display:flex;align-items:center;justify-content:center;border:1px solid #ece3ff}
.doc-thumb img{width:100%;height:100%;object-fit:cover}
.doc-thumb.placeholder{color:#7a6d98;font-weight:700}
.doc-slot-body{display:flex;flex-direction:column;gap:8px}
.doc-meta{font-size:13px;color:#675b86;display:grid;gap:4px}
.preview-wrap{padding:8px 0}
.preview-image{width:100%;border-radius:18px;border:1px solid #e8ddff}
.preview-frame{width:100%;height:70vh;border:none;border-radius:18px;background:#fff}
.modal-lg{max-width:920px;width:min(92vw,920px)}
@media (max-width:640px){
  .doc-grid-2{grid-template-columns:1fr}
}
