@import url('https://fonts.googleapis.com/css2?family=Sarabun:wght@300;400;500;600;700;800&display=swap');

:root{
  --bg:#f3f6fb;
  --panel:#ffffff;
  --panel2:#f8fbff;
  --text:#172033;
  --muted:#64748b;
  --line:#e2e8f0;
  --primary:#2357ff;
  --primary2:#142b83;
  --danger:#dc2626;
  --success:#16a34a;
  --warning:#d97706;
  --info:#0284c7;
  --shadow:0 16px 45px rgba(15,23,42,.08);
  --radius:18px;
  --sidebar:280px;
}
*{box-sizing:border-box}
body{
  margin:0;
  font-family:'Sarabun',Tahoma,Arial,sans-serif;
  color:var(--text);
  background:linear-gradient(135deg,#f7faff 0%,#eef4ff 50%,#f6f7fb 100%);
  font-size:15px;
}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font-family:inherit}
.app-shell{min-height:100vh;display:flex}
.sidebar{
  width:var(--sidebar);
  background:linear-gradient(180deg,#10192f 0%,#111827 100%);
  color:#fff;
  position:fixed;left:0;top:0;bottom:0;
  padding:18px;
  display:flex;flex-direction:column;
  z-index:50;
  box-shadow:10px 0 30px rgba(15,23,42,.18);
}
.brand-box{display:flex;gap:12px;align-items:center;padding:8px 8px 20px;border-bottom:1px solid rgba(255,255,255,.12)}
.brand-logo{width:44px;height:44px;border-radius:15px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);display:grid;place-items:center;font-weight:800}
.brand-title{font-weight:800;font-size:18px}
.brand-sub{font-size:12px;color:#cbd5e1}
.side-nav{padding:18px 0;display:flex;flex-direction:column;gap:8px;flex:1}
.side-link{
  display:flex;align-items:center;gap:12px;
  padding:13px 14px;border-radius:14px;color:#dbeafe;
  transition:.16s ease;font-weight:700;
}
.side-link:hover,.side-link.active{background:rgba(255,255,255,.12);color:#fff;transform:translateX(2px)}
.side-link.active{box-shadow:inset 3px 0 0 #60a5fa}
.side-icon{width:24px;text-align:center}
.side-footer{border-top:1px solid rgba(255,255,255,.12);padding-top:14px}
.user-mini{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.avatar{width:38px;height:38px;border-radius:14px;background:#e0ecff;color:#1d4ed8;display:grid;place-items:center;font-weight:800}
.user-name{font-weight:800;font-size:14px}
.user-role{font-size:12px;color:#cbd5e1}
.logout-link{display:block;background:rgba(239,68,68,.18);color:#fecaca;padding:11px;border-radius:14px;text-align:center;font-weight:800}

.main{margin-left:var(--sidebar);width:calc(100% - var(--sidebar));min-height:100vh}
.topbar{
  position:sticky;top:0;z-index:20;
  min-height:82px;background:rgba(255,255,255,.86);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(226,232,240,.9);
  display:flex;align-items:center;gap:16px;justify-content:space-between;
  padding:14px 26px;
}
.topbar h1{margin:0;font-size:22px}
.topbar p{margin:3px 0 0;color:var(--muted);font-size:13px}
.hamburger{display:none;border:0;background:#eef4ff;border-radius:12px;width:44px;height:44px;font-size:20px;cursor:pointer}
.top-user{display:flex;flex-direction:column;align-items:flex-end;color:var(--muted);font-size:13px}
.top-user b{color:var(--primary)}
.content{padding:24px 26px 40px}
.page-grid{display:grid;gap:18px}
.card{
  background:rgba(255,255,255,.96);
  border:1px solid rgba(226,232,240,.9);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:22px;
}
.card.compact{padding:16px}
.card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:18px;border-bottom:1px solid var(--line);padding-bottom:14px}
.card-head h2{margin:0;font-size:19px}
.card-head p{margin:4px 0 0;color:var(--muted);font-size:13px}
.badge{display:inline-flex;align-items:center;border-radius:999px;padding:6px 10px;font-weight:800;font-size:12px;background:#eef4ff;color:#1d4ed8}
.required-note{color:var(--muted);font-size:13px}
.form-block{margin-bottom:18px}
.form-section-label{
  display:flex;align-items:center;gap:10px;margin:8px 0 14px;
  font-weight:800;font-size:16px;color:#0f172a;
}
.step-dot{width:30px;height:30px;border-radius:12px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;display:grid;place-items:center;font-weight:800}
.grid{display:grid;gap:14px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.field label{display:block;margin:0 0 7px;font-weight:800;color:#25324a}
.req{color:var(--danger);margin-left:2px}
input,select,textarea{
  width:100%;border:1px solid #d6deeb;background:#fff;border-radius:13px;
  padding:11px 13px;min-height:44px;font-size:15px;outline:none;
  transition:.14s ease;
}
textarea{min-height:96px;resize:vertical}
input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 4px rgba(35,87,255,.10)}
.choice-row{display:flex;flex-wrap:wrap;gap:10px}
.choice{
  display:inline-flex;gap:8px;align-items:center;
  min-height:44px;padding:10px 13px;background:#fff;border:1px solid #d6deeb;border-radius:13px;
  font-weight:700;cursor:pointer;
}
.choice input{width:auto;min-height:auto}
.help{font-size:12px;color:var(--muted);margin-top:6px}
.form-actions{
  position:sticky;bottom:0;background:rgba(255,255,255,.88);
  backdrop-filter:blur(16px);border-top:1px solid var(--line);
  padding:14px 26px;margin:22px -26px -40px;display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;
}
.btn{
  border:0;border-radius:13px;min-height:43px;padding:10px 16px;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-weight:800;cursor:pointer;transition:.14s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff;box-shadow:0 12px 24px rgba(35,87,255,.20)}
.btn-secondary{background:#fff;border:1px solid var(--line);color:#273449}
.btn-danger{background:#dc2626;color:#fff}
.btn-success{background:#16a34a;color:#fff}
.btn-warning{background:#d97706;color:#fff}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:16px;background:#fff}
table{width:100%;border-collapse:collapse}
th,td{padding:12px 14px;border-bottom:1px solid var(--line);text-align:left;white-space:nowrap;vertical-align:middle}
th{background:#f8fafc;color:#334155;font-weight:900}
tr:hover td{background:#fbfdff}
.searchbar{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:end}
.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.kpi{background:linear-gradient(135deg,#fff,#f8fbff);border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:var(--shadow)}
.kpi .num{font-size:32px;font-weight:900}
.kpi .label{color:var(--muted);font-weight:700}
.status-pill{display:inline-flex;border-radius:999px;padding:6px 10px;font-weight:900;font-size:12px}
.status-wait{background:#fff7ed;color:#c2410c}
.status-info{background:#e0f2fe;color:#0369a1}
.status-warning{background:#fef3c7;color:#92400e}
.status-success{background:#dcfce7;color:#166534}
.status-danger{background:#fee2e2;color:#991b1b}
.alert{padding:14px 16px;border-radius:16px;font-weight:800;margin-bottom:16px}
.alert-danger{background:#fff1f2;color:#be123c;border:1px solid #fecdd3}
.alert-success{background:#ecfdf5;color:#047857;border:1px solid #bbf7d0}

.login-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(135deg,#0f172a 0%,#1d4ed8 55%,#f8fafc 55%,#eef4ff 100%)}
.login-card{width:min(460px,100%);background:#fff;border-radius:26px;padding:30px;box-shadow:0 30px 80px rgba(15,23,42,.25)}
.login-logo{width:58px;height:58px;border-radius:20px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;display:grid;place-items:center;font-size:26px;font-weight:900;margin-bottom:18px}
.login-card h1{margin:0 0 6px;font-size:27px}
.login-card p{margin:0 0 20px;color:var(--muted)}
.demo-users{background:#f8fafc;border:1px solid var(--line);border-radius:16px;padding:12px;margin-top:14px;color:#475569;font-size:13px;line-height:1.7}

.print-body{background:#fff;color:#000;font-family:'Sarabun',Tahoma,sans-serif;font-size:12px}
.print-page{width:210mm;min-height:297mm;margin:0 auto;background:#fff;padding:11mm 13mm;position:relative}
.print-head{display:flex;justify-content:space-between;font-size:10px;color:#333;margin-bottom:14mm}
.form-title{display:inline-block;border:2px solid #000;border-radius:6px;padding:8px 28px;font-weight:800;font-size:16px;margin:0 0 10mm 0}
.print-row{display:flex;gap:10px;margin:5px 0;align-items:flex-end}
.print-label{font-weight:600;white-space:nowrap}
.print-line{border-bottom:1px dotted #000;min-height:19px;flex:1;padding:0 6px}
.print-line.sm{flex:.55}.print-line.xs{flex:.25}
.print-check{display:inline-flex;align-items:center;gap:4px;margin-right:12px;white-space:nowrap}
.circle{width:11px;height:11px;border:1.5px solid #000;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:8px}
.circle.checked::after{content:"●";font-size:7px}
.print-section-title{display:inline-block;border:1.5px solid #000;padding:5px 9px;margin:10px 0 6px;font-weight:800}
.print-note{font-size:10px;font-style:italic;margin:5px 0}
.print-cols{display:grid;grid-template-columns:1fr 1fr;gap:18mm}
.print-contact-row{display:grid;grid-template-columns:22mm 35mm 35mm 1fr;gap:5px;align-items:end;margin:4px 0}
.print-actions{max-width:210mm;margin:16px auto;display:flex;gap:8px;justify-content:flex-end}

@media(max-width:1080px){
  .grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}
  .kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:860px){
  .sidebar{transform:translateX(-105%);transition:.18s ease}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0;width:100%}
  .hamburger{display:block}
  .topbar{padding:12px 16px}
  .top-user{display:none}
  .content{padding:16px}
  .grid-2,.grid-3,.grid-4,.kpi-grid{grid-template-columns:1fr}
  .searchbar{grid-template-columns:1fr}
  .form-actions{margin:22px -16px -40px;padding:12px 16px}
}
@media print{
  @page{size:A4;margin:0}
  body{background:#fff!important}
  .sidebar,.topbar,.content > .no-print,.print-actions,.no-print{display:none!important}
  .main{margin-left:0;width:100%}
  .content{padding:0}
  .print-page{box-shadow:none;margin:0;width:210mm;min-height:297mm;padding:11mm 13mm}
}


/* License dynamic upload */
.license-summary{
  border:1px solid #bfdbfe;
  background:linear-gradient(135deg,#eff6ff,#ffffff);
  border-radius:18px;
  padding:15px;
  margin-top:14px;
}
.license-summary h3{margin:0 0 8px;font-size:16px;color:#1e3a8a}
.doc-list{display:grid;gap:12px;margin-top:12px}
.doc-item{
  border:1px solid #e2e8f0;
  border-radius:16px;
  background:#fff;
  padding:14px;
  display:grid;
  grid-template-columns:1.3fr 1fr;
  gap:12px;
  align-items:center;
}
.doc-item strong{display:block;color:#0f172a}
.doc-item small{color:#64748b}
.doc-required{color:#dc2626;font-weight:900}
.existing-file{
  display:inline-flex;
  padding:5px 9px;
  border-radius:999px;
  background:#ecfdf5;
  color:#047857;
  font-size:12px;
  font-weight:800;
  margin-top:6px;
}
@media(max-width:860px){
  .doc-item{grid-template-columns:1fr}
}


/* LOB / Segment / Subsegment dropdown readability */
#lineOfBusiness, #segmentSelect, #subsegmentSelect{
  font-weight:700;
  background:#fff;
}

/* Address auto complete */
.address-search-box{
  background:#f8fbff;
  border:1px dashed #bfdbfe;
  border-radius:16px;
  padding:14px;
  margin-bottom:14px;
}

/* Page 2 map and signature */
.canvas-panel{
  border:1px solid #d7deea;
  border-radius:18px;
  background:#fff;
  padding:14px;
}
.canvas-toolbar{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  margin-bottom:10px;
}
.draw-canvas-wrap{
  width:100%;
  border:2px solid #a3c76d;
  border-radius:8px;
  background:#fff;
  overflow:hidden;
  touch-action:none;
}
.draw-canvas{
  width:100%;
  height:260px;
  display:block;
  background:#fff;
  cursor:crosshair;
}
.signature-canvas-wrap{
  border:1.8px dashed #94a3b8;
  border-radius:12px;
  background:#fff;
  overflow:hidden;
  touch-action:none;
}
.signature-canvas{
  width:100%;
  height:150px;
  display:block;
  background:#fff;
  cursor:crosshair;
}
.readonly-box{
  min-height:44px;
  border:1px solid #d6deeb;
  border-radius:13px;
  background:#f8fafc;
  padding:11px 13px;
  font-weight:800;
  color:#334155;
}
.print-map-box{
  width:100%;
  height:55mm;
  border:1.5px solid #91b85e;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.print-map-box img{
  max-width:100%;
  max-height:100%;
}
.print-sign-box{
  width:78mm;
  min-height:32mm;
  border:0;
  padding:6px 8px;
  margin-left:auto;
}
.print-sign-img{
  height:18mm;
  max-width:68mm;
  display:block;
  margin:2px auto 0;
}


/* Searchable address fields */
input[list$="_province_list"],
input[list$="_district_list"],
input[list$="_subdistrict_list"]{
  background:#ffffff;
}
.address-search-box input{
  border-color:#bfdbfe;
  background:#fff;
  font-weight:700;
}


/* Editable searchable address */
.address-search-box .help::after{
  content:"  เลือกแล้วสามารถแก้ไขเองต่อได้ทุกช่อง";
  color:#1d4ed8;
  font-weight:800;
}


/* === Patch: remove red frame from customer signature print box === */
.print-sign-box{
  border:0 !important;
}

.print-sign-box{border:0 !important;}


/* Attachment preview cards */
.card.compact{
  box-shadow:none;
}

/* Print attachment pages */
@media print{
  .print-page{
    page-break-after: always;
  }
}


/* Better attachment preview */
.attachment-preview-card{
  margin-top:12px;
}
@media print{
  .print-attachment-preview{
    width:100%;
  }
}


/* Restore required fields and dynamic option layout */
.license-summary{
  border:1px solid #bfdbfe;
  background:linear-gradient(135deg,#eff6ff,#ffffff);
  border-radius:18px;
  padding:15px;
  margin-top:14px;
}
.license-summary h3{
  margin:0 0 8px;
  font-size:16px;
  color:#1e3a8a;
}
.doc-list{
  display:grid;
  gap:12px;
  margin-top:12px;
}
.doc-item{
  border:1px solid #e2e8f0;
  border-radius:16px;
  background:#fff;
  padding:14px;
  display:grid;
  grid-template-columns:1.3fr 1fr;
  gap:12px;
  align-items:center;
}
.doc-item strong{display:block;color:#0f172a}
.doc-item small{color:#64748b}
.doc-required{color:#dc2626;font-weight:900}
.existing-file{
  display:inline-flex;
  padding:5px 9px;
  border-radius:999px;
  background:#ecfdf5;
  color:#047857;
  font-size:12px;
  font-weight:800;
  margin-top:6px;
}
#lineOfBusiness, #segmentSelect, #subsegmentSelect, #licenseCode{
  font-weight:700;
  background:#fff;
}
@media(max-width:860px){
  .doc-item{grid-template-columns:1fr}
}


/* === iPad / mobile responsive patch 20260429 === */
html, body{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
  -webkit-text-size-adjust:100%;
}
img, iframe, canvas, video{
  max-width:100%;
}
input, select, textarea, button{
  max-width:100%;
  font-size:16px; /* iOS ไม่ zoom ตอนกดกรอก */
}
input[type="file"]{
  width:100%;
  white-space:normal;
}
.table-wrap{
  width:100%;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
}
.content, .card, .main, form{
  max-width:100%;
}
.grid, .grid-2, .grid-3, .grid-4{
  min-width:0;
}
.field{
  min-width:0;
}
.field input,
.field select,
.field textarea{
  width:100%;
}

@media(max-width:1180px){
  :root{--sidebar:0px}
  .app-shell{display:block;min-height:100dvh}
  .sidebar{
    transform:translateX(-105%);
    transition:.18s ease;
    width:280px;
    max-width:86vw;
  }
  .sidebar.open{transform:translateX(0)}
  .main{
    margin-left:0 !important;
    width:100% !important;
    min-width:0;
  }
  .hamburger{display:block !important}
  .topbar{
    padding:12px max(14px, env(safe-area-inset-left)) 12px max(14px, env(safe-area-inset-left));
    gap:10px;
    position:sticky;
    top:0;
    z-index:40;
  }
  .topbar h1{
    font-size:20px;
    line-height:1.25;
  }
  .topbar p{
    font-size:13px;
  }
  .top-user{
    display:none;
  }
  .content{
    padding:14px;
    padding-bottom:92px;
  }
  .card{
    border-radius:16px;
    padding:14px;
    margin-bottom:14px;
  }
  .grid-2,.grid-3,.grid-4,.kpi-grid{
    grid-template-columns:1fr !important;
    gap:12px;
  }
  .doc-item{
    grid-template-columns:1fr !important;
  }
  .searchbar{
    grid-template-columns:1fr !important;
  }
  .form-actions{
    position:sticky;
    bottom:0;
    z-index:30;
    margin:18px -14px -14px;
    padding:10px 14px calc(10px + env(safe-area-inset-bottom));
    background:rgba(255,255,255,.96);
    backdrop-filter:blur(10px);
    border-top:1px solid #e2e8f0;
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    justify-content:flex-end;
  }
  .form-actions .btn,
  .form-actions button{
    flex:1 1 140px;
    justify-content:center;
    text-align:center;
  }
  .draw-canvas{height:220px}
  .signature-canvas{height:160px}
}

@media(max-width:640px){
  body{font-size:14px}
  .topbar h1{font-size:18px}
  .content{padding:10px;padding-bottom:96px}
  .card{padding:12px;border-radius:14px}
  .btn{padding:10px 12px}
  .form-section-label{font-size:15px}
  .step-dot{width:28px;height:28px}
}


/* === Print map/signature fix === */
/* แสดง map/signature อยู่ในหน้า 2 เท่านั้น ไม่แยกเป็นหน้าแนบ */
@media print{
  .print-map-box{
    height:43mm !important;
  }
  .print-map-box img{
    max-width:100% !important;
    max-height:42mm !important;
    object-fit:contain;
  }
  .print-sign-box{
    min-height:26mm !important;
    margin-top:5mm !important;
  }
  .print-sign-img{
    height:14mm !important;
    max-width:62mm !important;
    object-fit:contain;
  }
  .print-missing-img{
    font-size:10px;
    color:#777;
    text-align:center;
  }
}


/* === Print full attachment content: image / PDF / DOCX === */
.attachment-title-box{
  display:inline-block;
  border:2px solid #000;
  border-radius:6px;
  padding:7px 20px;
  font-weight:900;
  margin:8mm 0 10mm;
}
.att-meta{
  display:grid;
  grid-template-columns:22mm 1fr;
  gap:2mm 5mm;
  font-size:12px;
  margin-bottom:6mm;
}
.att-meta b{
  font-weight:900;
}
.att-image-wrap{
  width:100%;
  min-height:150mm;
  display:flex;
  align-items:flex-start;
  justify-content:center;
  border:1px solid #000;
  padding:5mm;
}
.att-image-wrap img{
  max-width:100%;
  max-height:230mm;
  object-fit:contain;
}
.att-error{
  border:1px solid #000;
  padding:8mm;
  line-height:1.7;
  font-size:13px;
  min-height:35mm;
}
.pdf-render-status{
  border:1px solid #000;
  padding:8mm;
  line-height:1.7;
  margin-bottom:6mm;
}
.pdf-page-wrap{
  page-break-after:always;
  break-after:page;
  display:flex;
  justify-content:center;
  align-items:flex-start;
  width:100%;
  min-height:260mm;
}
.pdf-page-wrap:last-child{
  page-break-after:auto;
  break-after:auto;
}
.pdf-canvas-page{
  max-width:100%;
  height:auto;
  border:1px solid #ddd;
}
.docx-print-text{
  border:1px solid #000;
  padding:6mm;
  line-height:1.55;
  font-size:12px;
  white-space:normal;
}
.docx-print-image{
  margin:5mm 0;
  text-align:center;
  page-break-inside:avoid;
  break-inside:avoid;
}
.docx-print-image img{
  max-width:100%;
  max-height:220mm;
  object-fit:contain;
}
.att-open-note{
  margin-top:5mm;
  font-size:11px;
  color:#555;
  border-top:1px dashed #999;
  padding-top:3mm;
}
@media print{
  .print-attachment-page{
    page-break-after:always;
    break-after:page;
  }
  .print-attachment-page:last-child{
    page-break-after:auto;
    break-after:auto;
  }
  .pdf-canvas-page{
    width:100% !important;
    max-height:none !important;
  }
}


/* Lock edit button while document is under review */
.btn-disabled{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  border:1px solid #cbd5e1;
  background:#f1f5f9;
  color:#64748b !important;
  cursor:not-allowed;
  opacity:.85;
  pointer-events:none;
}
