:root {
    --ink: #15251f;
    --muted: #69766f;
    --line: #dce6df;
    --paper: #ffffff;
    --surface: #f4f8f5;
    --green-950: #0f2f25;
    --green-800: #164a3a;
    --green-700: #1f664d;
    --green-600: #267b5b;
    --lime: #dff4d7;
    --gold: #e3ad3b;
    --danger: #bb3f45;
    --radius-lg: 22px;
    --radius-md: 15px;
    --shadow: 0 15px 34px rgba(24, 58, 43, .10);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    min-height: 100vh;
    background: var(--surface);
    color: var(--ink);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
small { font-size: .83em; }

.container { width: min(1180px, calc(100% - 40px)); margin: 0 auto; }
.page-section { padding: 42px 0 56px; }
.narrow-page { width: min(900px, calc(100% - 40px)); }
.mt-4 { margin-top: 1.5rem; }
.mt-3 { margin-top: 1rem; }
.mb-0 { margin-bottom: 0; }
.w-100 { width: 100%; }
.text-muted { color: var(--muted); }
.small { font-size: .87rem; }

.topbar {
    position: sticky;
    top: 0;
    z-index: 20;
    background: rgba(255, 255, 255, .94);
    border-bottom: 1px solid var(--line);
    backdrop-filter: blur(12px);
}
.topbar-inner { min-height: 72px; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.brand { display: inline-flex; align-items: center; gap: 11px; color: var(--green-950); }
.brand-mark { width: 39px; height: 39px; display: grid; place-items: center; border-radius: 12px; background: var(--green-800); color: white; font-size: .84rem; font-weight: 900; letter-spacing: .04em; }
.brand-text { display: grid; gap: 1px; line-height: 1.05; }
.brand-text strong { font-size: .98rem; }
.brand-text small { color: var(--muted); font-size: .69rem; letter-spacing: .08em; text-transform: uppercase; }
.brand-light { color: white; }
.brand-light .brand-mark { background: var(--gold); color: var(--green-950); }
.brand-light .brand-text small { color: rgba(255,255,255,.68); }

.main-nav { display: flex; align-items: center; gap: 4px; }
.main-nav > a, .install-app-button { border: 0; border-radius: 10px; background: transparent; color: #42564c; padding: 9px 10px; font-size: .89rem; font-weight: 650; }
.main-nav > a:hover { background: #edf5ef; color: var(--green-800); }
.main-nav .nav-signout { color: var(--danger); }
.install-app-button { background: var(--green-800); color: white; padding: 9px 13px; }
.install-app-button:hover { background: var(--green-700); }
.nav-toggle { display: none; border: 0; background: transparent; padding: 7px; }
.nav-toggle span { display: block; width: 22px; height: 2px; margin: 4px; background: var(--green-950); }

.offline-strip { position: sticky; top: 72px; z-index: 19; padding: 8px 20px; background: #f9dca0; color: #5f4300; text-align: center; font-size: .88rem; font-weight: 650; }
.site-footer { border-top: 1px solid var(--line); background: white; color: var(--muted); font-size: .82rem; }
.footer-content { min-height: 72px; display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; }

.eyebrow { display: inline-block; color: var(--green-700); font-size: .72rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.eyebrow-light { color: #d6f2d8; }
.page-heading { display: flex; align-items: end; justify-content: space-between; gap: 22px; margin-bottom: 24px; }
.page-heading h1, .hero h1, .order-header-card h1 { margin: 6px 0 8px; font-size: clamp(1.9rem, 4vw, 3.1rem); letter-spacing: -.035em; line-height: 1.08; }
.page-heading p, .hero p { margin: 0; color: var(--muted); max-width: 720px; line-height: 1.6; }

.hero { position: relative; overflow: hidden; display: flex; justify-content: space-between; gap: 30px; align-items: stretch; padding: 38px; border-radius: var(--radius-lg); color: white; background: linear-gradient(135deg, var(--green-950), var(--green-700)); box-shadow: var(--shadow); }
.hero::after { content: ""; position: absolute; width: 300px; height: 300px; right: -130px; top: -120px; border: 1px solid rgba(255,255,255,.18); border-radius: 50%; box-shadow: 0 0 0 42px rgba(255,255,255,.06), 0 0 0 84px rgba(255,255,255,.04); }
.hero > * { position: relative; z-index: 1; }
.hero h1 { max-width: 750px; }
.hero p { color: rgba(255,255,255,.76); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 22px; }
.hero-panel { align-self: end; min-width: 210px; display: grid; gap: 7px; padding: 20px; border: 1px solid rgba(255,255,255,.18); border-radius: var(--radius-md); background: rgba(255,255,255,.09); backdrop-filter: blur(5px); }
.hero-panel strong { font-size: 1.27rem; }
.hero-panel span:not(.panel-label) { color: rgba(255,255,255,.78); font-size: .89rem; }
.panel-label { color: #d6f2d8; font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; font-weight: 800; }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; min-height: 42px; border: 1px solid transparent; border-radius: 11px; padding: 10px 15px; font-size: .92rem; font-weight: 750; transition: transform .18s ease, box-shadow .18s ease, background .18s ease; }
.btn:hover { transform: translateY(-1px); }
.btn:disabled { opacity: .65; cursor: wait; transform: none; }
.btn-primary { background: var(--green-800); color: white; box-shadow: 0 8px 16px rgba(22, 74, 58, .18); }
.hero .btn-primary { background: white; color: var(--green-800); }
.btn-primary:hover { background: var(--green-700); color: white; }
.hero .btn-primary:hover { background: #edf8ef; }
.btn-secondary { background: transparent; color: var(--green-800); border-color: #b9d2bf; }
.hero .btn-secondary { color: white; border-color: rgba(255,255,255,.42); }
.btn-secondary:hover { background: #eaf4ec; }
.btn-outline { background: white; color: var(--green-800); border-color: #c7d8cb; }
.btn-outline:hover { background: #eef7ef; }
.btn-small { min-height: 34px; padding: 7px 10px; font-size: .82rem; }
.text-button { padding: 0; border: 0; color: var(--green-700); background: transparent; font-size: .85rem; font-weight: 700; text-decoration: underline; }

.metrics-grid { display: grid; gap: 16px; }
.three-up { grid-template-columns: repeat(3, 1fr); }
.five-up { grid-template-columns: repeat(5, 1fr); }
.metric-card { min-height: 150px; display: flex; flex-direction: column; padding: 19px; border: 1px solid var(--line); border-radius: var(--radius-md); background: var(--paper); box-shadow: 0 6px 18px rgba(30, 61, 44, .04); }
.metric-card:hover { border-color: #bdd4c2; }
.metric-label { color: var(--muted); font-size: .8rem; font-weight: 730; }
.metric-number { margin: 8px 0 2px; color: var(--green-800); font-size: 2rem; letter-spacing: -.05em; }
.metric-card small { color: #77857d; margin-top: auto; }
.metric-alert .metric-number { color: var(--danger); }

.section-card { padding: 25px; border: 1px solid var(--line); border-radius: var(--radius-lg); background: var(--paper); box-shadow: 0 6px 18px rgba(30, 61, 44, .04); }
.section-header { display: flex; align-items: start; justify-content: space-between; gap: 20px; margin-bottom: 18px; }
.section-header h2, .form-section h2, .timeline-card h2, .action-stack-title h2 { margin: 4px 0 5px; font-size: 1.28rem; letter-spacing: -.02em; }
.section-header p, .form-section > p { margin: 0; color: var(--muted); font-size: .91rem; }
.small-header { margin-bottom: 16px; }

.order-list { border-top: 1px solid #edf1ee; }
.order-row { display: grid; grid-template-columns: minmax(0, 1fr) auto auto; align-items: center; gap: 20px; padding: 16px 6px; border-bottom: 1px solid #edf1ee; transition: background .16s ease; }
.order-row:hover { background: #f7fbf8; }
.order-row-main { min-width: 0; display: grid; gap: 4px; }
.order-row-main strong { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.order-row-main span, .order-row-meta, .due-date { color: var(--muted); font-size: .81rem; }
.order-row-meta { display: flex; align-items: center; justify-content: end; gap: 10px; }

.status-badge, .priority-badge, .role-chip, .action-status { display: inline-flex; align-items: center; width: max-content; border-radius: 999px; padding: 5px 9px; font-size: .73rem; line-height: 1; font-weight: 800; white-space: nowrap; }
.status-blue { background: #dbeafe; color: #1e4e8c; }
.status-teal { background: #d8f2ef; color: #146058; }
.status-amber { background: #fff2cd; color: #855c00; }
.status-purple { background: #eee8ff; color: #6242aa; }
.status-orange { background: #fde5c8; color: #9c4d00; }
.status-green { background: #dff3df; color: #236c36; }
.status-red { background: #ffe2e4; color: #a4313a; }
.status-gray { background: #e9eceb; color: #59645e; }
.priority-normal { background: #edf1ee; color: #56625b; }
.priority-high { background: #fff0cf; color: #965c00; }
.priority-urgent { background: #ffe0e2; color: #b42c37; }

.empty-state { padding: 38px 22px; text-align: center; color: var(--muted); }
.empty-state h3 { margin: 0 0 8px; color: var(--ink); font-size: 1.13rem; }
.empty-state p { margin: 0 0 17px; }

.form-section + .form-section { margin-top: 30px; padding-top: 28px; border-top: 1px solid var(--line); }
.form-grid { display: grid; gap: 16px; }
.two-col { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.full { grid-column: 1 / -1; }
.form-group { display: grid; gap: 7px; }
.form-group label { font-size: .86rem; font-weight: 740; color: #35473e; }
.form-group label span { color: var(--danger); }
.form-group label small { color: var(--muted); font-weight: 550; }
.form-group input, .form-group select, .form-group textarea, .item-row input, .filters-grid input, .filters-grid select {
    width: 100%; border: 1px solid #cbd8ce; border-radius: 10px; outline: none; background: #fff; color: var(--ink); padding: 10px 11px; transition: border-color .15s ease, box-shadow .15s ease;
}
.form-group textarea { resize: vertical; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus, .item-row input:focus, .filters-grid input:focus, .filters-grid select:focus { border-color: var(--green-600); box-shadow: 0 0 0 3px rgba(38,123,91,.13); }
.form-actions { display: flex; justify-content: end; gap: 10px; margin-top: 30px; padding-top: 24px; border-top: 1px solid var(--line); }
.form-feedback { margin-top: 14px; border-radius: 10px; padding: 10px 12px; font-size: .88rem; }
.feedback-success { background: #e7f7e8; color: #246c35; }
.feedback-error { background: #ffe7e8; color: #9d2831; }

.item-table { overflow-x: auto; }
.item-row { min-width: 750px; display: grid; grid-template-columns: minmax(180px, 2fr) 90px 170px minmax(160px, 1.2fr) 36px; gap: 9px; align-items: center; padding: 8px 0; border-bottom: 1px solid #edf1ee; }
.item-row-heading { color: var(--muted); font-size: .78rem; font-weight: 750; text-transform: uppercase; letter-spacing: .04em; }
.item-row-heading span:last-child { visibility: hidden; }
.icon-button { width: 31px; height: 31px; border: 1px solid #f0c4c8; border-radius: 8px; background: #fff4f4; color: #af3d44; font-size: 1.3rem; line-height: 1; }
.icon-button:hover { background: #ffe5e6; }

.filters-grid { display: grid; grid-template-columns: minmax(210px, 1.4fr) minmax(160px, .8fr) minmax(180px, 1fr) auto; gap: 14px; align-items: end; }
.filter-button { display: flex; }
.filter-button .btn { width: 100%; }

.breadcrumb { display: flex; align-items: center; gap: 8px; margin-bottom: 16px; color: var(--muted); font-size: .85rem; }
.breadcrumb a { color: var(--green-700); font-weight: 700; }
.order-header-card { display: flex; align-items: stretch; justify-content: space-between; gap: 24px; padding: 30px; border-radius: var(--radius-lg); background: white; border: 1px solid var(--line); box-shadow: var(--shadow); }
.order-header-tags { display: flex; gap: 8px; flex-wrap: wrap; }
.order-header-card h1 { font-size: clamp(1.6rem, 3vw, 2.4rem); max-width: 780px; }
.order-header-card p { margin: 0; color: var(--muted); }
.order-header-side { min-width: 210px; align-self: center; display: grid; gap: 5px; padding-left: 23px; border-left: 1px solid var(--line); }
.order-header-side span { color: var(--muted); font-size: .76rem; font-weight: 750; text-transform: uppercase; letter-spacing: .07em; }
.order-header-side strong { color: var(--green-800); font-size: 1.1rem; }
.order-header-side small { color: var(--muted); }
.detail-layout { display: grid; grid-template-columns: minmax(0, 1.6fr) minmax(320px, .85fr); gap: 22px; align-items: start; }
.detail-aside { min-width: 0; }
.detail-list { display: grid; gap: 16px; }
.detail-list.two-columns { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.detail-list.compact { gap: 12px; }
.detail-list > div { min-width: 0; }
.detail-list dt { color: var(--muted); font-size: .76rem; font-weight: 780; letter-spacing: .06em; text-transform: uppercase; }
.detail-list dd { margin: 4px 0 0; font-weight: 650; word-break: break-word; }
.justification-box { margin-top: 23px; padding: 15px; border-left: 4px solid #9ccdae; background: #f3faf4; border-radius: 0 10px 10px 0; }
.justification-box span { color: var(--green-700); font-size: .76rem; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; }
.justification-box p { margin: 8px 0 0; line-height: 1.6; }
.table-wrap { overflow-x: auto; }
.data-table { width: 100%; border-collapse: collapse; min-width: 610px; }
.data-table th { padding: 10px; border-bottom: 1px solid var(--line); color: var(--muted); text-align: left; font-size: .75rem; letter-spacing: .05em; text-transform: uppercase; }
.data-table td { padding: 12px 10px; border-bottom: 1px solid #edf1ee; font-size: .9rem; }
.attachment-list { display: grid; margin: 0; padding: 0; list-style: none; }
.attachment-list li { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 12px 0; border-bottom: 1px solid #edf1ee; }
.attachment-list li:last-child { border-bottom: 0; }
.attachment-list li div { display: grid; min-width: 0; gap: 3px; }
.attachment-list strong { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.attachment-list span { color: var(--muted); font-size: .8rem; }

.timeline { display: grid; gap: 0; padding: 0; margin: 16px 0 0; list-style: none; }
.timeline li { position: relative; display: grid; grid-template-columns: 18px minmax(0, 1fr); gap: 10px; padding: 0 0 20px; }
.timeline li:not(:last-child)::before { content: ""; position: absolute; width: 2px; background: #dbe7de; left: 8px; top: 17px; bottom: 0; }
.timeline-dot { width: 17px; height: 17px; border: 3px solid white; border-radius: 50%; box-shadow: 0 0 0 1px #c9d9ce; }
.timeline li strong { display: block; font-size: .9rem; }
.timeline li span:not(.timeline-dot) { display: block; margin-top: 2px; color: var(--muted); font-size: .76rem; }
.timeline li p { margin: 7px 0 0; color: #4b5a51; font-size: .83rem; line-height: 1.45; }
.map-link { display: inline-block; margin-top: 7px; color: var(--green-700); font-size: .81rem; font-weight: 700; text-decoration: underline; }

.action-stack { display: grid; gap: 13px; }
.action-stack-title { margin: 0 0 3px; }
.action-card { display: grid; gap: 12px; padding: 18px; border: 1px solid #dce8df; border-radius: var(--radius-md); background: white; box-shadow: 0 5px 15px rgba(30,61,44,.04); }
.action-card-head { display: flex; justify-content: space-between; gap: 12px; align-items: start; }
.action-card h3 { margin: 0; font-size: 1rem; }
.action-status { background: #eff6f0; color: var(--green-700); }
.geo-row { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; }
.location-status { color: var(--muted); font-size: .78rem; }
.action-card-actions { display: flex; justify-content: end; }

.login-page { min-height: calc(100vh - 72px); display: grid; place-items: center; padding: 34px 20px; background: linear-gradient(140deg, #ecf6ec, #f8fbf8); }
.login-card { width: min(1000px, 100%); display: grid; grid-template-columns: 1.05fr .95fr; overflow: hidden; border-radius: 24px; background: white; box-shadow: 0 22px 65px rgba(22, 74, 58, .16); }
.login-aside { padding: 44px; color: white; background: linear-gradient(140deg, var(--green-950), var(--green-700)); }
.login-aside h1 { margin: 24px 0 13px; font-size: clamp(2rem, 4vw, 3.1rem); line-height: 1.06; letter-spacing: -.045em; }
.login-aside p { color: rgba(255,255,255,.75); line-height: 1.65; }
.login-points { display: grid; gap: 15px; margin-top: 29px; }
.login-points > div { display: grid; grid-template-columns: 33px minmax(0,1fr); gap: 11px; align-items: start; color: rgba(255,255,255,.83); font-size: .9rem; line-height: 1.45; }
.login-points strong { color: var(--gold); font-size: 1.05rem; }
.login-form { padding: 44px; }
.login-form h2 { margin: 14px 0 6px; letter-spacing: -.03em; }
.role-chip { background: #e8f4e8; color: var(--green-700); }
.notice { padding: 13px; border: 1px solid #d7e6d9; border-radius: 11px; background: #f5fbf6; color: #425348; }
.notice code { padding: 1px 5px; border-radius: 4px; background: #e4eee5; color: var(--green-800); }
.profile-card { display: flex; align-items: center; gap: 21px; }
.profile-avatar { width: 76px; height: 76px; display: grid; place-items: center; flex: 0 0 auto; border-radius: 50%; background: var(--green-800); color: white; font-size: 1.9rem; font-weight: 800; }
.profile-details h2 { margin: 0; }

.alert { border-radius: 11px; }

@media (max-width: 1000px) {
    .five-up { grid-template-columns: repeat(3, 1fr); }
    .detail-layout { grid-template-columns: 1fr; }
    .detail-aside { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 20px; }
    .detail-aside .action-stack { grid-column: 1 / -1; }
}

@media (max-width: 780px) {
    .container, .narrow-page { width: min(100% - 28px, 1180px); }
    .topbar-inner { min-height: 64px; }
    .nav-toggle { display: block; }
    .main-nav { display: none; position: absolute; top: 64px; left: 0; right: 0; padding: 12px 14px; flex-direction: column; align-items: stretch; border-bottom: 1px solid var(--line); background: white; box-shadow: 0 12px 22px rgba(20, 40, 28, .08); }
    .main-nav.is-open { display: flex; }
    .main-nav > a, .install-app-button { width: 100%; text-align: left; }
    .install-app-button { text-align: center; }
    .offline-strip { top: 64px; }
    .page-section { padding: 28px 0 42px; }
    .page-heading, .order-header-card { align-items: start; flex-direction: column; }
    .page-heading h1 { font-size: 2rem; }
    .hero { padding: 28px; flex-direction: column; }
    .hero-panel { align-self: stretch; min-width: 0; }
    .three-up, .five-up { grid-template-columns: repeat(2, 1fr); }
    .section-card { padding: 20px; }
    .order-row { grid-template-columns: minmax(0, 1fr) auto; gap: 10px; }
    .order-row-meta { grid-row: 2; grid-column: 1 / -1; justify-content: start; }
    .order-row > .status-badge { grid-column: 2; grid-row: 1; }
    .two-col, .detail-list.two-columns, .filters-grid { grid-template-columns: 1fr; }
    .filter-button { display: grid; }
    .detail-aside { display: block; }
    .detail-aside .action-stack { margin-top: 20px; }
    .order-header-side { width: 100%; min-width: 0; padding: 16px 0 0; border-top: 1px solid var(--line); border-left: 0; }
    .login-card { grid-template-columns: 1fr; }
    .login-aside, .login-form { padding: 30px; }
    .login-aside { padding-bottom: 32px; }
    .footer-content { padding: 16px 0; }
}

@media (max-width: 480px) {
    .three-up, .five-up { grid-template-columns: 1fr; }
    .hero { padding: 24px; }
    .hero h1 { font-size: 2rem; }
    .form-actions { flex-direction: column-reverse; }
    .form-actions .btn { width: 100%; }
    .section-header { flex-direction: column; }
    .attachment-list li { align-items: start; flex-direction: column; }
}


/* Score-upgrade modules: Smart Assistant, QR confirmation and advanced analytics */
.btn-gold { background: var(--gold, #d49a25); border-color: var(--gold, #d49a25); color: #1c2e25; font-weight: 780; }
.btn-gold:hover { filter: brightness(.96); color: #1c2e25; }
.assistant-card { display:grid; grid-template-columns:auto minmax(0,1fr) auto; gap:18px; align-items:center; padding:24px; border:1px solid #ead9ae; border-radius:16px; background:linear-gradient(135deg,#fffdf5,#fbf6e6); }
.assistant-card h2 { margin:4px 0 5px; font-size:1.2rem; }.assistant-card p{margin:0;color:#58635c;line-height:1.55}.assistant-icon{width:44px;height:44px;display:grid;place-items:center;border-radius:13px;background:#f2d88b;color:#5e470d;font-size:1.3rem}.assistant-result{grid-column:2/-1;padding:15px 16px;border-radius:12px;background:#fff;border:1px solid #ead9ae;color:#435047}.assistant-result p{margin:9px 0}.assistant-result ul{margin:8px 0 12px;padding-left:20px}.assistant-result li{margin:4px 0}.assistant-result.assistant-error{border-color:#edc4c8;background:#fff5f5;color:#973943}.assistant-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.assistant-actions span{font-size:.78rem;color:var(--muted)}.assistant-score{margin-left:6px;font-size:.75rem;color:#6b5b26}
.risk-badge{display:inline-flex;align-items:center;min-height:25px;padding:4px 8px;border-radius:99px;font-size:.72rem;font-weight:800;white-space:nowrap}.risk-high{background:#ffe2e4;color:#9e2732}.risk-medium{background:#fff0cb;color:#916005}.risk-low{background:#e9f3e8;color:#376d45}.risk-none{background:#edf0ee;color:#617068}.risk-explain-card{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;padding:22px;border:1px solid #efdaa5;border-radius:var(--radius-md);background:#fffaf0}.risk-explain-card h2{margin:5px 0 6px;font-size:1.2rem}.risk-explain-card p{margin:0;color:#5b625d}.risk-explain-card ul{margin:12px 0 0;padding-left:20px}.risk-explain-card li{margin:4px 0;font-size:.9rem}.risk-list{display:grid}.risk-row{display:flex;justify-content:space-between;gap:18px;align-items:center;padding:16px 0;border-bottom:1px solid var(--line);color:inherit}.risk-row:last-child{border-bottom:0}.risk-row strong,.risk-row span,.risk-row small{display:block}.risk-row span{color:var(--muted);font-size:.84rem;margin-top:3px}.risk-row small{color:#725815;margin-top:5px}.risk-score{display:grid;gap:6px;justify-items:end}.risk-score b{font-size:1.2rem;color:#a13d31}.analytics-note{padding:6px 10px;border-radius:99px;background:#eef6ef;color:var(--green-700);font-size:.77rem;font-weight:750}.analytics-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.chart-card{min-height:290px;padding:16px;border:1px solid #dfe8e1;border-radius:13px;background:#fff}.chart-card h3{font-size:1rem;margin:0 0 10px}.chart-card canvas{display:block;width:100%;height:220px}.chart-fallback{display:flex;gap:9px 13px;flex-wrap:wrap;margin-top:4px;font-size:.76rem;color:#5d6a61}.chart-fallback span{display:inline-flex;gap:5px;align-items:center}.chart-fallback i{width:9px;height:9px;border-radius:3px;display:inline-block}.performance-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.performance-grid>div{padding:14px;border-radius:11px;background:#f4f8f5;border:1px solid #e0ebe1}.performance-grid span{display:block;color:var(--muted);font-size:.78rem}.performance-grid strong{display:block;margin-top:4px;color:var(--green-800);font-size:1.2rem}.delivery-qr-card{display:flex;align-items:center;justify-content:space-between;gap:25px;padding:24px;border:1px solid #b8d3bf;border-radius:var(--radius-md);background:linear-gradient(130deg,#eff8f0,#fff)}.delivery-qr-card h2{margin:5px 0 7px;font-size:1.25rem}.delivery-qr-card p{color:#536258;max-width:650px;margin:0}.delivery-code{display:inline-block;margin:16px 0 5px;padding:10px 14px;border-radius:10px;letter-spacing:.13em;background:#123a2b;color:#fff;font-weight:850;font-size:1.22rem}.delivery-qr-card small{display:block;color:#647168}.qr-wrap{width:154px;min-width:154px;padding:10px;border-radius:12px;background:#fff;box-shadow:0 5px 16px rgba(18,52,38,.12)}.qr-wrap svg{width:100%;height:auto;display:block}.qr-confirm-help{padding:12px;border:1px solid #d9e5dc;border-radius:10px;background:#f7fbf8}.qr-confirm-help p{margin:0 0 9px;font-size:.86rem;color:#56635b}.qr-confirm-help video{width:100%;max-height:220px;object-fit:cover;margin-top:10px;border-radius:9px;background:#1c2b24}.live-update-label{margin-left:auto;font-size:.75rem;color:#4d765c}.breadcrumb .live-update-label{font-weight:700}.action-card .form-group input[name="delivery_code"]{letter-spacing:.15em;text-transform:uppercase}
@media(max-width:780px){.assistant-card{grid-template-columns:auto minmax(0,1fr)}.assistant-card .btn{grid-column:1/-1;width:100%}.assistant-result{grid-column:1/-1}.analytics-grid{grid-template-columns:1fr}.performance-grid{grid-template-columns:1fr}.delivery-qr-card{align-items:flex-start;flex-direction:column}.qr-wrap{width:180px}.risk-explain-card,.risk-row{align-items:flex-start;flex-direction:column}.risk-score{justify-items:start}.live-update-label{display:none}}

/* -------------------------------------------------------------------------
   Mobile hardening: prevent horizontal page scroll and make every workflow
   usable at 320–430px width. Desktop/tablet behaviour remains unchanged.
   ------------------------------------------------------------------------- */
html,
body {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
}

main,
.topbar,
.site-footer,
.container,
.narrow-page,
.page-section,
.hero,
.section-card,
.order-header-card,
.detail-layout,
.detail-main,
.detail-aside,
.action-stack,
.action-card,
.assistant-card,
.risk-explain-card,
.delivery-qr-card,
.analytics-grid,
.chart-card,
.performance-grid,
.profile-card,
.login-card,
.login-aside,
.login-form,
.order-row,
.order-row-main,
.order-row-meta,
.risk-row,
.item-row,
.item-field,
.form-grid,
.form-group,
.form-section {
    min-width: 0;
    max-width: 100%;
}

img,
svg,
canvas,
video {
    max-width: 100%;
}

.order-row-main span,
.order-row-main strong,
.risk-row strong,
.risk-row span,
.risk-row small,
.order-header-card h1,
.order-header-card p,
.page-heading p,
.hero p,
.timeline li p,
.attachment-list span,
.attachment-list strong,
.form-group label,
.justification-box p,
.detail-list dd {
    overflow-wrap: anywhere;
    word-break: normal;
}

.breadcrumb {
    flex-wrap: wrap;
    line-height: 1.4;
}

.analytics-grid > *,
.performance-grid > *,
.detail-layout > *,
.hero > *,
.login-card > *,
.order-row > *,
.risk-row > * {
    min-width: 0;
}

.item-field {
    min-width: 0;
}

.item-field > label {
    display: none;
}

@media (max-width: 780px) {
    .container,
    .narrow-page {
        width: calc(100% - 28px);
        max-width: none;
    }

    .topbar-inner {
        gap: 12px;
    }

    .brand {
        min-width: 0;
    }

    .brand-text {
        min-width: 0;
    }

    .brand-text strong {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .page-section {
        padding: 22px 0 36px;
    }

    .page-heading {
        gap: 12px;
        margin-bottom: 18px;
    }

    .page-heading h1,
    .hero h1 {
        font-size: clamp(1.75rem, 8vw, 2.2rem);
    }

    .hero {
        gap: 18px;
        padding: 20px;
        border-radius: 17px;
    }

    .hero::after {
        right: -190px;
        top: -180px;
    }

    .hero-actions {
        display: grid;
        grid-template-columns: 1fr;
        margin-top: 18px;
    }

    .hero-actions .btn {
        width: 100%;
    }

    .hero-panel {
        padding: 15px;
    }

    .metrics-grid {
        gap: 10px;
    }

    .three-up,
    .five-up {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .three-up > :last-child:nth-child(odd),
    .five-up > :last-child:nth-child(odd) {
        grid-column: 1 / -1;
    }

    .metric-card {
        min-height: 112px;
        padding: 14px;
        border-radius: 14px;
    }

    .metric-number {
        margin-top: 6px;
        font-size: 1.65rem;
    }

    .metric-card small {
        line-height: 1.3;
    }

    .section-card,
    .order-header-card {
        padding: 16px;
        border-radius: 15px;
    }

    .section-header {
        gap: 12px;
        margin-bottom: 14px;
    }

    .section-header .btn {
        width: 100%;
    }

    .order-header-card {
        gap: 16px;
    }

    .order-header-card h1 {
        font-size: 1.5rem;
        line-height: 1.15;
    }

    .order-header-card p {
        font-size: .83rem;
        line-height: 1.45;
    }

    .order-header-side {
        padding-top: 13px;
    }

    .order-row {
        grid-template-columns: minmax(0, 1fr) auto;
        padding: 14px 0;
    }

    .order-row-main {
        gap: 6px;
    }

    .order-row-main strong {
        white-space: normal;
        overflow: visible;
        text-overflow: clip;
        line-height: 1.35;
    }

    .order-row-main span {
        line-height: 1.4;
    }

    .order-row-meta {
        gap: 6px;
        flex-wrap: wrap;
        line-height: 1.3;
    }

    .status-badge,
    .priority-badge,
    .role-chip,
    .action-status,
    .risk-badge {
        max-width: 138px;
        white-space: normal;
        line-height: 1.25;
        text-align: center;
    }

    .data-table {
        min-width: 0;
    }

    .table-wrap {
        overflow: visible;
    }

    .data-table,
    .data-table tbody,
    .data-table tr,
    .data-table td {
        display: block;
        width: 100%;
    }

    .data-table thead {
        display: none;
    }

    .data-table tr {
        padding: 8px 0;
        border-bottom: 1px solid var(--line);
    }

    .data-table tr:last-child {
        border-bottom: 0;
    }

    .data-table td {
        display: grid;
        grid-template-columns: minmax(96px, .9fr) minmax(0, 1.35fr);
        gap: 10px;
        padding: 7px 0;
        border: 0;
        text-align: right;
        overflow-wrap: anywhere;
    }

    .data-table td::before {
        content: attr(data-label);
        color: var(--muted);
        font-size: .73rem;
        font-weight: 800;
        letter-spacing: .04em;
        text-align: left;
        text-transform: uppercase;
    }

    .item-table {
        overflow: visible;
    }

    .item-row-heading {
        display: none;
    }

    .item-row {
        min-width: 0;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 12px;
        margin-bottom: 12px;
        padding: 14px;
        border: 1px solid #dce8df;
        border-radius: 13px;
        background: #f8fbf8;
    }

    .item-row:not(.item-row-heading) .item-field:first-child,
    .item-row:not(.item-row-heading) .item-field:nth-child(4) {
        grid-column: 1 / -1;
    }

    .item-field > label {
        display: block;
        color: #35473e;
        font-size: .78rem;
        font-weight: 760;
    }

    .item-field > label span {
        color: var(--danger);
    }

    .item-row .icon-button {
        align-self: end;
        justify-self: end;
        grid-column: 2;
    }

    .form-group input,
    .form-group select,
    .form-group textarea,
    .item-row input,
    .filters-grid input,
    .filters-grid select {
        font-size: 16px;
    }

    .form-actions,
    .action-card-actions {
        display: grid;
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .form-actions .btn,
    .action-card-actions .btn {
        width: 100%;
    }

    .action-stack {
        gap: 12px;
    }

    .action-card {
        gap: 13px;
        padding: 16px;
        border-radius: 14px;
    }

    .action-card-head {
        align-items: flex-start;
        flex-direction: column;
    }

    .action-status {
        align-self: flex-start;
        max-width: none;
    }

    .geo-row {
        align-items: flex-start;
        flex-direction: column;
    }

    .text-button {
        text-align: left;
    }

    .attachment-list li {
        gap: 10px;
    }

    .attachment-list .btn {
        width: 100%;
    }

    .delivery-qr-card,
    .risk-explain-card,
    .risk-row,
    .profile-card {
        padding: 16px;
    }

    .qr-wrap {
        align-self: center;
        width: min(100%, 190px);
        min-width: 0;
    }

    .assistant-card {
        gap: 13px;
        padding: 16px;
    }

    .assistant-card .assistant-icon {
        width: 38px;
        height: 38px;
    }

    .assistant-card h2,
    .risk-explain-card h2 {
        font-size: 1.08rem;
    }

    .chart-card {
        min-height: 250px;
        padding: 13px;
    }

    .chart-card canvas {
        height: 200px;
    }

    .performance-grid > div {
        padding: 13px;
    }

    .login-page {
        min-height: auto;
        padding: 0;
        background: var(--surface);
    }

    .login-card {
        width: 100%;
        border-radius: 0;
        box-shadow: none;
    }

    .login-aside,
    .login-form {
        padding: 24px 18px;
    }

    .login-aside {
        padding-bottom: 26px;
    }

    .login-points {
        gap: 12px;
        margin-top: 20px;
    }

    .footer-content {
        align-items: flex-start;
        flex-direction: column;
        gap: 5px;
        padding: 16px 0;
    }
}

@media (max-width: 360px) {
    .container,
    .narrow-page {
        width: calc(100% - 22px);
    }

    .brand-text small {
        display: none;
    }

    .three-up,
    .five-up,
    .item-row {
        grid-template-columns: 1fr;
    }

    .three-up > :last-child:nth-child(odd),
    .five-up > :last-child:nth-child(odd),
    .item-row:not(.item-row-heading) .item-field:first-child,
    .item-row:not(.item-row-heading) .item-field:nth-child(4),
    .item-row .icon-button {
        grid-column: auto;
    }

    .item-row .icon-button {
        justify-self: start;
    }
}


/* Clean-release user guidance */
.guide-hero {
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    gap: 26px;
    padding: 34px;
    overflow: hidden;
    border-radius: var(--radius-lg);
    background: linear-gradient(135deg, var(--green-950), var(--green-700));
    box-shadow: var(--shadow);
    color: #fff;
}
.guide-hero > div { min-width: 0; }
.guide-hero h1 { margin: 7px 0 10px; font-size: clamp(1.9rem, 4vw, 3rem); letter-spacing: -.035em; }
.guide-hero p { max-width: 720px; margin: 0; color: rgba(255, 255, 255, .78); line-height: 1.62; }
.guide-role-card {
    display: grid;
    align-content: center;
    gap: 6px;
    min-width: 220px;
    padding: 18px;
    border: 1px solid rgba(255, 255, 255, .2);
    border-radius: 14px;
    background: rgba(255, 255, 255, .1);
}
.guide-role-card span,
.guide-role-card small { color: rgba(255, 255, 255, .75); font-size: .82rem; }
.guide-role-card strong { font-size: 1.25rem; }
.guide-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.guide-grid-two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.guide-card { display: flex; flex-direction: column; min-width: 0; }
.guide-card h2 { margin: 10px 0 10px; font-size: 1.18rem; }
.guide-card p { color: var(--muted); line-height: 1.58; }
.guide-card ol,
.guide-card ul { margin: 0 0 20px; padding-left: 20px; color: #46564d; line-height: 1.58; }
.guide-card li + li { margin-top: 7px; }
.guide-card .btn { margin-top: auto; }
.guide-step {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: max-content;
    min-height: 27px;
    padding: 5px 9px;
    border-radius: 999px;
    background: #eaf4ec;
    color: var(--green-700);
    font-size: .73rem;
    font-weight: 800;
    letter-spacing: .06em;
}
.guide-status-flow {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
}
.guide-status-flow li {
    position: relative;
    min-width: 0;
    padding: 14px 13px;
    border: 1px solid #dce8df;
    border-radius: 12px;
    background: #f8fbf8;
}
.guide-status-flow strong,
.guide-status-flow span { display: block; }
.guide-status-flow strong { color: var(--green-800); font-size: .87rem; }
.guide-status-flow span { margin-top: 5px; color: var(--muted); font-size: .78rem; line-height: 1.4; }
.demo-accounts-card { display: flex; align-items: center; justify-content: space-between; gap: 22px; }
.demo-accounts-card h2 { margin: 4px 0 0; font-size: 1.2rem; }
.guide-account-list { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; min-width: min(100%, 580px); margin: 0; }
.guide-account-list > div { min-width: 0; padding: 12px; border: 1px solid #dce8df; border-radius: 11px; background: #f8fbf8; }
.guide-account-list dt { color: var(--muted); font-size: .74rem; font-weight: 800; text-transform: uppercase; letter-spacing: .05em; }
.guide-account-list dd { margin: 5px 0 0; overflow-wrap: anywhere; color: var(--green-800); font-size: .86rem; font-weight: 700; }
.quick-guide-banner { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 16px 18px; border: 1px solid #d7e5d9; border-radius: 15px; background: #edf7ef; }
.quick-guide-banner > div { display: grid; gap: 4px; min-width: 0; }
.quick-guide-banner strong { color: #2d493a; font-size: .92rem; }

@media (max-width: 1000px) {
    .guide-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .guide-status-flow { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .demo-accounts-card { align-items: flex-start; flex-direction: column; }
    .guide-account-list { width: 100%; }
}

@media (max-width: 780px) {
    .guide-hero { align-items: flex-start; flex-direction: column; padding: 25px; }
    .guide-role-card { width: 100%; min-width: 0; }
    .guide-grid,
    .guide-grid-two,
    .guide-status-flow { grid-template-columns: 1fr; }
    .quick-guide-banner { align-items: flex-start; flex-direction: column; }
    .quick-guide-banner .btn { width: 100%; }
}

@media (max-width: 480px) {
    .guide-hero { padding: 22px 20px; }
    .guide-hero h1 { font-size: 1.85rem; }
    .guide-card,
    .demo-accounts-card { padding: 18px; }
    .guide-account-list { grid-template-columns: 1fr; }
}
