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

:root {
  --navy: #123a4a;
  --navy-2: #0b2c39;
  --teal: #18a7a0;
  --teal-dark: #0d817e;
  --mint: #e8f7f4;
  --blue-soft: #eaf3f7;
  --orange: #f39b55;
  --red: #d86662;
  --green: #2f9c74;
  --ink: #182c35;
  --muted: #6e8087;
  --line: #dfe8eb;
  --surface: #ffffff;
  --canvas: #f4f7f8;
  --shadow: 0 14px 40px rgba(18, 58, 74, .08);
  --radius: 18px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--canvas); color: var(--ink); font-family: 'DM Sans', Arial, sans-serif; }
button, input, select, textarea { font: inherit; }
a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
button, a, select { -webkit-tap-highlight-color: transparent; }

.topbar { height: 78px; padding: 0 34px; display: flex; align-items: center; gap: 32px; color: #fff; background: var(--navy); position: sticky; top: 0; z-index: 50; box-shadow: 0 5px 22px rgba(7, 35, 46, .14); }
.brand { display: inline-flex; align-items: center; gap: 10px; min-width: 205px; }
.brand-mark { width: 41px; height: 41px; display: grid; place-items: center; color: var(--teal); background: #fff; border-radius: 13px; transform: rotate(-4deg); box-shadow: 0 4px 14px rgba(0,0,0,.14); }
.brand-mark svg { width: 29px; fill: none; stroke: currentColor; stroke-width: 2.2; }
.brand > span:last-child { display: grid; line-height: 1; }
.brand strong { font-family: 'Manrope', sans-serif; letter-spacing: .18em; font-size: 18px; }
.brand small { margin-top: 5px; color: #a9d7d4; font-weight: 700; letter-spacing: .35em; font-size: 8px; }
.public-nav { display: flex; align-items: center; gap: 30px; margin-left: auto; }
.public-nav a { color: #dce8eb; font-size: 14px; font-weight: 500; }
.public-nav a:hover { color: #fff; }
.top-actions { display: flex; gap: 10px; }
.topbar-search { width: min(480px, 44vw); display: flex; align-items: center; gap: 10px; margin: 0 auto; padding: 0 16px; border: 1px solid rgba(255,255,255,.15); border-radius: 12px; background: rgba(255,255,255,.09); }
.topbar-search svg { width: 18px; fill: none; stroke: #b9ced4; stroke-width: 1.8; }
.topbar-search input { width: 100%; height: 42px; border: 0; outline: 0; color: #fff; background: transparent; }
.topbar-search input::placeholder { color: #9fb8c0; }
.user-menu { display: flex; align-items: center; gap: 10px; min-width: 260px; }
.user-menu > span { display: grid; }
.user-menu strong { font-size: 13px; }
.user-menu small { margin-top: 2px; color: #9db8c0; font-size: 11px; }
.user-menu .chevron { margin-left: auto; color: #a7c0c7; }
.avatar { width: 39px; height: 39px; display: grid; place-items: center; border: 2px solid rgba(255,255,255,.35); border-radius: 50%; color: var(--navy); background: #d8eeea; font-weight: 800; font-size: 12px; }
.icon-button { position: relative; border: 0; color: #fff; background: transparent; cursor: pointer; }
.notification-dot { width: 7px; height: 7px; position: absolute; top: 1px; right: 2px; border-radius: 50%; background: var(--orange); }
.mobile-menu { display: none; color: #fff; border: 0; background: transparent; font-size: 22px; }

.app-shell { min-height: calc(100vh - 78px); display: grid; grid-template-columns: 236px 1fr; }
.sidebar { padding: 24px 16px; display: flex; flex-direction: column; border-right: 1px solid var(--line); background: #fff; }
.role-switcher { padding: 13px; margin-bottom: 20px; background: var(--canvas); border-radius: 12px; }
.role-switcher label { display: block; margin: 0 0 7px 4px; color: var(--muted); font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; }
.role-switcher select { width: 100%; padding: 8px 9px; border: 1px solid var(--line); border-radius: 8px; color: var(--ink); background: #fff; font-weight: 700; outline: 0; }
.sidebar-nav { display: grid; gap: 5px; }
.sidebar-nav a { min-height: 43px; padding: 0 12px; display: flex; align-items: center; gap: 12px; color: #51656d; border-radius: 10px; font-size: 14px; font-weight: 600; }
.sidebar-nav a:hover { color: var(--navy); background: var(--canvas); }
.sidebar-nav a.active { color: var(--navy); background: var(--mint); }
.sidebar-nav a.active::before { content: ''; width: 3px; height: 22px; position: absolute; left: 0; background: var(--teal); border-radius: 0 4px 4px 0; }
.nav-icon { width: 22px; color: var(--teal-dark); text-align: center; font-weight: 800; font-size: 18px; }
.nav-badge { min-width: 20px; height: 20px; margin-left: auto; display: grid; place-items: center; border-radius: 20px; color: #fff; background: var(--orange); font-size: 10px; }
.sidebar-help { margin-top: auto; padding: 18px; display: grid; justify-items: start; background: linear-gradient(145deg, var(--navy), #185568); color: #fff; border-radius: 14px; }
.sidebar-help > span { width: 29px; height: 29px; display: grid; place-items: center; margin-bottom: 10px; border-radius: 50%; color: var(--navy); background: #fff; font-weight: 800; }
.sidebar-help strong { font-size: 13px; }
.sidebar-help small { margin: 4px 0 11px; color: #bcd0d5; font-size: 11px; }
.sidebar-help a { color: #75e2da; font-size: 11px; font-weight: 700; }
.sidebar-exit { margin-top: 17px; color: var(--muted); text-align: center; font-size: 12px; }
.main-content { width: 100%; max-width: 1600px; padding: 32px 36px 54px; overflow: hidden; }

.page-heading { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; margin-bottom: 25px; }
.eyebrow { margin: 0 0 6px; color: var(--teal-dark); font-weight: 800; font-size: 11px; text-transform: uppercase; letter-spacing: .12em; }
h1, h2, h3, h4 { margin-top: 0; font-family: 'Manrope', sans-serif; }
h1 { margin-bottom: 6px; color: var(--navy); font-size: clamp(26px, 3vw, 34px); letter-spacing: -.04em; }
h2 { color: var(--navy); font-size: 21px; letter-spacing: -.02em; }
h3 { color: var(--ink); font-size: 16px; }
p { line-height: 1.6; }
.page-heading p, .section-heading p { margin: 0; color: var(--muted); font-size: 14px; }
.section-heading { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; margin-bottom: 18px; }
.section-heading h2 { margin-bottom: 4px; }
.text-link { color: var(--teal-dark); font-size: 13px; font-weight: 800; }
.text-link:hover { color: var(--navy); }

.btn { min-height: 42px; padding: 0 18px; display: inline-flex; align-items: center; justify-content: center; gap: 8px; border: 1px solid transparent; border-radius: 10px; cursor: pointer; font-weight: 700; font-size: 13px; transition: .2s ease; }
.btn:hover { transform: translateY(-1px); }
.btn-primary { color: #fff; background: var(--teal-dark); box-shadow: 0 8px 18px rgba(13,129,126,.18); }
.btn-primary:hover { background: #096e6c; }
.btn-secondary { color: var(--navy); background: var(--mint); }
.btn-outline { color: var(--navy); background: #fff; border-color: var(--line); }
.btn-danger-soft { color: #a43d3a; background: #fff1f0; }
.btn-light { color: var(--navy); background: #fff; }
.btn-ghost-light { color: #fff; border-color: rgba(255,255,255,.45); }
.btn-lg { min-height: 50px; padding: 0 25px; border-radius: 12px; font-size: 14px; }
.btn-sm { min-height: 34px; padding: 0 13px; font-size: 11px; }

.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 28px; }
.stat-card { min-height: 132px; padding: 20px; position: relative; overflow: hidden; border: 1px solid var(--line); border-radius: var(--radius); background: #fff; box-shadow: 0 7px 22px rgba(18,58,74,.035); }
.stat-card::after { content: ''; width: 72px; height: 72px; position: absolute; right: -19px; bottom: -23px; border-radius: 50%; background: var(--mint); }
.stat-card > span { color: var(--muted); font-size: 12px; font-weight: 600; }
.stat-card strong { display: block; margin: 9px 0 5px; color: var(--navy); font-family: 'Manrope'; font-size: 29px; }
.stat-card small { color: var(--muted); font-size: 11px; }
.stat-card small.positive { color: var(--green); }
.stat-icon { width: 35px; height: 35px; position: absolute; top: 17px; right: 17px; display: grid; place-items: center; border-radius: 10px; color: var(--teal-dark); background: var(--mint); font-weight: 800; }

.dashboard-grid { display: grid; grid-template-columns: minmax(0, 1.65fr) minmax(280px, .85fr); gap: 20px; }
.card { border: 1px solid var(--line); border-radius: var(--radius); background: #fff; box-shadow: 0 8px 25px rgba(18,58,74,.04); }
.card-pad { padding: 23px; }
.card + .card { margin-top: 20px; }
.request-list { display: grid; }
.request-row { padding: 17px 0; display: grid; grid-template-columns: 52px 1.5fr .8fr .8fr auto; align-items: center; gap: 14px; border-top: 1px solid var(--line); }
.request-row:first-child { border-top: 0; }
.request-thumb { width: 47px; height: 47px; display: grid; place-items: center; border-radius: 12px; color: var(--teal-dark); background: linear-gradient(145deg, var(--mint), #d8eeef); font-size: 22px; }
.request-info strong, .request-cell strong { display: block; margin-bottom: 3px; font-size: 13px; }
.request-info small, .request-cell small { color: var(--muted); font-size: 11px; }
.status { padding: 6px 9px; display: inline-flex; align-items: center; gap: 5px; border-radius: 30px; white-space: nowrap; font-size: 10px; font-weight: 800; }
.status::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.status-blue { color: #267895; background: #e9f5f9; }
.status-orange { color: #a85f24; background: #fff3e9; }
.status-green { color: #27805f; background: #e9f7f1; }
.status-gray { color: #6d7b80; background: #f0f3f4; }
.status-red { color: #a94743; background: #fff0ef; }
.progress-card { padding: 23px; }
.progress-card h3 { margin-bottom: 5px; }
.progress-card > p { margin: 0 0 20px; color: var(--muted); font-size: 12px; }
.timeline { position: relative; padding-left: 31px; }
.timeline::before { content: ''; width: 2px; position: absolute; top: 8px; bottom: 8px; left: 10px; background: var(--line); }
.timeline-item { min-height: 61px; position: relative; }
.timeline-item::before { content: ''; width: 16px; height: 16px; position: absolute; left: -29px; top: 2px; border: 4px solid #fff; border-radius: 50%; background: #c7d3d7; box-shadow: 0 0 0 1px var(--line); }
.timeline-item.done::before { background: var(--green); }
.timeline-item.current::before { background: var(--orange); box-shadow: 0 0 0 4px #fff0e3; }
.timeline-item strong { display: block; font-size: 12px; }
.timeline-item small { color: var(--muted); font-size: 10px; }

.form-shell { max-width: 1050px; margin: 0 auto; }
.stepper { margin-bottom: 25px; display: grid; grid-template-columns: repeat(4, 1fr); }
.step { position: relative; display: flex; align-items: center; gap: 9px; color: #99a8ad; font-size: 11px; font-weight: 700; }
.step::after { content: ''; height: 2px; position: absolute; left: 36px; right: 10px; top: 14px; background: var(--line); z-index: 0; }
.step:last-child::after { display: none; }
.step span { width: 29px; height: 29px; display: grid; place-items: center; z-index: 1; border: 2px solid var(--line); border-radius: 50%; background: var(--canvas); }
.step.active { color: var(--navy); }
.step.active span { color: #fff; border-color: var(--teal-dark); background: var(--teal-dark); }
.step.active::after { background: linear-gradient(90deg, var(--teal-dark) 38%, var(--line) 38%); }
.form-card { padding: 30px; }
.form-section { padding-bottom: 25px; margin-bottom: 25px; border-bottom: 1px solid var(--line); }
.form-section:last-child { padding-bottom: 0; margin-bottom: 0; border: 0; }
.form-section h2 { margin-bottom: 4px; font-size: 18px; }
.form-section > p { margin: 0 0 19px; color: var(--muted); font-size: 12px; }
.form-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 17px; }
.form-grid-3 { grid-template-columns: repeat(3, 1fr); }
.field { display: grid; gap: 7px; }
.field-full { grid-column: 1 / -1; }
.field label { color: #41565e; font-size: 11px; font-weight: 800; }
.field label small { color: var(--muted); font-weight: 400; }
.field input, .field select, .field textarea { width: 100%; min-height: 44px; padding: 10px 13px; border: 1px solid #cfdbde; border-radius: 10px; outline: 0; color: var(--ink); background: #fff; }
.field textarea { min-height: 98px; resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus { border-color: var(--teal); box-shadow: 0 0 0 3px rgba(24,167,160,.1); }
.option-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 11px; }
.option-card { padding: 15px; display: grid; gap: 7px; border: 1px solid var(--line); border-radius: 12px; cursor: pointer; }
.option-card:has(input:checked) { border-color: var(--teal-dark); background: var(--mint); box-shadow: inset 0 0 0 1px var(--teal-dark); }
.option-card input { width: 15px; height: 15px; accent-color: var(--teal-dark); }
.option-card strong { font-size: 12px; }
.option-card small { color: var(--muted); font-size: 10px; }
.upload-zone { min-height: 180px; padding: 28px; display: grid; place-items: center; text-align: center; border: 2px dashed #b8cdcf; border-radius: 15px; background: #fbfdfd; cursor: pointer; }
.upload-zone:hover, .upload-zone.has-file { border-color: var(--teal); background: var(--mint); }
.upload-zone input { display: none; }
.upload-icon { width: 48px; height: 48px; display: grid; place-items: center; border-radius: 50%; color: var(--teal-dark); background: var(--mint); font-size: 23px; }
.upload-zone strong { margin-top: 10px; font-size: 13px; }
.upload-zone small { color: var(--muted); font-size: 10px; }
.form-footer { margin-top: 20px; display: flex; align-items: center; justify-content: space-between; }
.privacy-note { display: flex; align-items: center; gap: 9px; color: var(--muted); font-size: 11px; }
.privacy-note span { color: var(--green); font-size: 18px; }

.filter-bar { padding: 10px; display: flex; align-items: center; gap: 8px; margin-bottom: 18px; border: 1px solid var(--line); border-radius: 14px; background: #fff; }
.filter-bar button { padding: 9px 14px; border: 0; border-radius: 9px; color: var(--muted); background: transparent; cursor: pointer; font-size: 11px; font-weight: 700; }
.filter-bar button.active { color: #fff; background: var(--navy); }
.filter-bar .filter-spacer { margin-left: auto; }
.service-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.service-card { padding: 20px; position: relative; border: 1px solid var(--line); border-radius: 16px; background: #fff; box-shadow: 0 8px 24px rgba(18,58,74,.04); }
.service-card[hidden] { display: none; }
.service-card:hover { border-color: #b8d1d4; transform: translateY(-2px); box-shadow: var(--shadow); }
.service-top { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 16px; }
.service-id { color: var(--muted); font-size: 10px; font-weight: 700; }
.service-card h3 { margin-bottom: 8px; color: var(--navy); font-size: 16px; }
.service-card > p { min-height: 38px; margin: 0 0 15px; color: var(--muted); font-size: 11px; }
.service-meta { padding: 14px 0; display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.service-meta span { display: grid; gap: 3px; color: var(--muted); font-size: 9px; text-transform: uppercase; letter-spacing: .04em; }
.service-meta strong { color: var(--ink); font-size: 11px; text-transform: none; letter-spacing: 0; }
.service-footer { margin-top: 15px; display: flex; align-items: center; justify-content: space-between; }
.service-price small { display: block; color: var(--muted); font-size: 9px; }
.service-price strong { color: var(--navy); font-family: 'Manrope'; font-size: 16px; }

.detail-layout { display: grid; grid-template-columns: minmax(0, 1.6fr) minmax(310px, .7fr); gap: 20px; }
.detail-hero { padding: 24px; }
.detail-title { display: flex; align-items: flex-start; justify-content: space-between; gap: 20px; }
.detail-title h2 { margin: 6px 0; }
.detail-title p { margin: 0; color: var(--muted); font-size: 11px; }
.detail-kpis { padding: 18px 0; margin: 20px 0; display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.detail-kpis span { padding: 0 15px; display: grid; gap: 4px; border-left: 1px solid var(--line); color: var(--muted); font-size: 9px; text-transform: uppercase; }
.detail-kpis span:first-child { padding-left: 0; border-left: 0; }
.detail-kpis strong { color: var(--ink); font-size: 12px; text-transform: none; }
.tabs { display: flex; gap: 22px; border-bottom: 1px solid var(--line); }
.tabs button { padding: 0 2px 12px; border: 0; border-bottom: 2px solid transparent; color: var(--muted); background: transparent; cursor: pointer; font-size: 11px; font-weight: 800; }
.tabs button.active { color: var(--teal-dark); border-color: var(--teal-dark); }
.tab-panel { padding-top: 20px; }
.tab-panel[hidden] { display: none; }
.note-box { padding: 16px; color: #50636a; border-radius: 12px; background: var(--canvas); font-size: 12px; line-height: 1.6; }
.file-row { padding: 13px; margin-top: 12px; display: flex; align-items: center; gap: 12px; border: 1px solid var(--line); border-radius: 11px; }
.file-icon { width: 37px; height: 37px; display: grid; place-items: center; border-radius: 9px; color: var(--teal-dark); background: var(--mint); font-size: 11px; font-weight: 800; }
.file-row strong { display: block; font-size: 11px; }
.file-row small { color: var(--muted); font-size: 9px; }
.file-row a { margin-left: auto; color: var(--teal-dark); font-size: 11px; font-weight: 800; }
.side-card { padding: 22px; }
.price-highlight { padding: 18px; margin: 15px 0; border-radius: 13px; background: var(--mint); }
.price-highlight small { display: block; color: var(--muted); font-size: 10px; }
.price-highlight strong { color: var(--navy); font-family: 'Manrope'; font-size: 27px; }
.price-highlight span { display: block; margin-top: 4px; color: var(--green); font-size: 10px; }
.side-actions { display: grid; gap: 9px; }
.side-actions .btn { width: 100%; }
.info-list { display: grid; gap: 13px; }
.info-list div { display: flex; justify-content: space-between; gap: 20px; color: var(--muted); font-size: 11px; }
.info-list strong { color: var(--ink); text-align: right; }

.moderation-board { display: grid; grid-template-columns: repeat(4, minmax(235px, 1fr)); gap: 15px; overflow-x: auto; padding-bottom: 8px; }
.board-column { padding: 12px; border-radius: 15px; background: #edf2f3; }
.board-heading { padding: 4px 4px 13px; display: flex; align-items: center; justify-content: space-between; }
.board-heading h3 { margin: 0; font-size: 12px; }
.board-count { width: 22px; height: 22px; display: grid; place-items: center; border-radius: 50%; color: var(--navy); background: #fff; font-size: 9px; font-weight: 800; }
.board-card { padding: 15px; margin-bottom: 10px; border: 1px solid var(--line); border-radius: 12px; background: #fff; box-shadow: 0 4px 10px rgba(18,58,74,.04); }
.board-card h4 { margin: 9px 0 5px; color: var(--navy); font-size: 12px; }
.board-card p { margin: 0 0 12px; color: var(--muted); font-size: 10px; }
.board-card-footer { display: flex; align-items: center; justify-content: space-between; color: var(--muted); font-size: 9px; }
.sla { color: #a85f24; font-weight: 800; }

.hero { min-height: 590px; padding: 75px max(5vw, 34px); position: relative; overflow: hidden; display: grid; grid-template-columns: 1.02fr .98fr; align-items: center; gap: 60px; color: #fff; background: linear-gradient(120deg, var(--navy-2) 0%, var(--navy) 63%, #18586a 100%); }
.hero::before { content: ''; width: 440px; height: 440px; position: absolute; right: 4%; top: 48px; border: 1px solid rgba(255,255,255,.08); border-radius: 50%; box-shadow: 0 0 0 85px rgba(255,255,255,.025), 0 0 0 170px rgba(255,255,255,.018); }
.hero-copy { max-width: 640px; position: relative; z-index: 2; }
.hero-badge { padding: 7px 12px; display: inline-flex; align-items: center; gap: 7px; border: 1px solid rgba(255,255,255,.16); border-radius: 40px; color: #bbebe7; background: rgba(255,255,255,.06); font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .1em; }
.hero-badge::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: #58d8ce; box-shadow: 0 0 0 4px rgba(88,216,206,.12); }
.hero h1 { max-width: 660px; margin: 20px 0 18px; color: #fff; font-size: clamp(38px, 5vw, 64px); line-height: 1.05; letter-spacing: -.055em; }
.hero h1 span { color: #64d9d1; }
.hero-copy > p { max-width: 570px; margin: 0 0 27px; color: #c1d4d9; font-size: 16px; }
.hero-actions { display: flex; gap: 12px; }
.hero-trust { margin-top: 29px; display: flex; flex-wrap: wrap; gap: 20px; color: #afc5cb; font-size: 10px; }
.hero-trust span::before { content: '✓'; margin-right: 7px; color: #6ce0d7; font-weight: 800; }
.hero-demo { min-height: 430px; position: relative; z-index: 2; }
.hero-card { width: min(435px, 100%); padding: 21px; position: absolute; right: 5%; top: 10px; color: var(--ink); border: 1px solid rgba(255,255,255,.5); border-radius: 20px; background: rgba(255,255,255,.96); box-shadow: 0 30px 70px rgba(4,29,39,.35); transform: rotate(1.2deg); }
.hero-card-head { display: flex; align-items: center; justify-content: space-between; }
.hero-card-head small { color: var(--muted); font-size: 9px; text-transform: uppercase; letter-spacing: .08em; }
.hero-card-head strong { display: block; margin-top: 4px; color: var(--navy); font-size: 14px; }
.mini-file { height: 155px; margin: 17px 0; display: grid; place-items: center; position: relative; overflow: hidden; border-radius: 14px; background: linear-gradient(145deg, #e8f4f3, #d2e6e8); }
.tooth-model { width: 130px; height: 85px; position: relative; filter: drop-shadow(0 12px 10px rgba(18,58,74,.18)); }
.tooth-model::before, .tooth-model::after { content: ''; width: 58px; height: 72px; position: absolute; top: 4px; border-radius: 52% 48% 42% 42% / 40% 40% 60% 60%; background: linear-gradient(140deg, #fff, #dce9e9); }
.tooth-model::before { left: 18px; transform: rotate(-12deg); }
.tooth-model::after { right: 18px; transform: rotate(12deg); }
.mini-progress { display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; }
.mini-progress span { height: 5px; border-radius: 10px; background: var(--line); }
.mini-progress span.done { background: var(--teal); }
.floating-card { padding: 13px 16px; position: absolute; display: flex; align-items: center; gap: 10px; color: var(--ink); border-radius: 13px; background: #fff; box-shadow: 0 18px 42px rgba(4,29,39,.28); }
.floating-card span { width: 32px; height: 32px; display: grid; place-items: center; color: var(--green); border-radius: 50%; background: #e8f7f1; font-weight: 800; }
.floating-card strong { display: block; font-size: 10px; }
.floating-card small { color: var(--muted); font-size: 8px; }
.floating-one { left: -10px; bottom: 52px; }
.floating-two { right: -8px; bottom: -8px; }

.public-section { padding: 80px max(5vw, 34px); }
.public-section.alt { background: #fff; }
.public-title { max-width: 650px; margin: 0 auto 43px; text-align: center; }
.public-title h2 { margin: 9px 0; font-size: clamp(28px, 4vw, 40px); }
.public-title p { margin: 0; color: var(--muted); }
.process-grid { max-width: 1150px; margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.process-card { padding: 24px; position: relative; border: 1px solid var(--line); border-radius: 16px; background: #fff; }
.process-card:not(:last-child)::after { content: '→'; position: absolute; right: -18px; top: 32px; color: var(--teal); font-size: 18px; }
.process-number { width: 38px; height: 38px; display: grid; place-items: center; margin-bottom: 17px; border-radius: 12px; color: #fff; background: var(--navy); font-family: 'Manrope'; font-weight: 800; }
.process-card h3 { margin-bottom: 8px; }
.process-card p { margin: 0; color: var(--muted); font-size: 12px; }
.feature-split { max-width: 1150px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 70px; align-items: center; }
.feature-copy h2 { margin: 10px 0 15px; font-size: 38px; }
.feature-copy > p { color: var(--muted); }
.check-list { margin: 24px 0; display: grid; gap: 15px; }
.check-list div { display: grid; grid-template-columns: 34px 1fr; gap: 11px; align-items: start; }
.check-list span { width: 31px; height: 31px; display: grid; place-items: center; border-radius: 9px; color: var(--green); background: #e8f7f1; font-weight: 800; }
.check-list strong { font-size: 13px; }
.check-list small { display: block; margin-top: 3px; color: var(--muted); font-size: 11px; }
.security-visual { min-height: 390px; padding: 30px; display: grid; place-items: center; position: relative; overflow: hidden; border-radius: 30px 30px 70px 30px; background: linear-gradient(145deg, var(--navy), #1a6575); }
.security-ring { width: 230px; height: 230px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.18); border-radius: 50%; box-shadow: 0 0 0 45px rgba(255,255,255,.035), 0 0 0 90px rgba(255,255,255,.025); }
.security-ring span { width: 100px; height: 100px; display: grid; place-items: center; border-radius: 30px; color: var(--teal); background: #fff; font-size: 45px; }
.site-footer { padding: 35px max(5vw, 34px); display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 40px; color: #b4c9cf; background: #082733; font-size: 11px; }
.footer-brand { color: #fff; }
.site-footer p { margin: 0; }

.empty-state { padding: 50px 20px; text-align: center; }
.empty-state span { width: 52px; height: 52px; display: grid; place-items: center; margin: 0 auto 13px; border-radius: 50%; color: var(--teal-dark); background: var(--mint); font-size: 24px; }
.empty-state h3 { margin-bottom: 5px; }
.empty-state p { margin: 0 0 16px; color: var(--muted); font-size: 12px; }
.toast { min-width: 290px; padding: 14px 18px; position: fixed; right: 24px; bottom: 24px; z-index: 100; display: grid; gap: 3px; color: #fff; border-radius: 12px; background: var(--navy); box-shadow: var(--shadow); transform: translateY(120px); opacity: 0; transition: .25s ease; }
.toast.show { transform: translateY(0); opacity: 1; }
.toast strong { font-size: 12px; }
.toast span { color: #bdd1d6; font-size: 10px; }

@media (max-width: 1100px) {
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .service-grid { grid-template-columns: repeat(2, 1fr); }
  .public-nav { display: none; }
  .hero { grid-template-columns: 1fr 1fr; gap: 25px; }
  .process-grid { grid-template-columns: repeat(2, 1fr); }
  .process-card::after { display: none; }
}

@media (max-width: 820px) {
  .topbar { height: 68px; padding: 0 18px; }
  .topbar-search { display: none; }
  .user-menu { min-width: 0; margin-left: auto; }
  .user-menu > span, .user-menu .chevron, .icon-button { display: none; }
  .mobile-menu { display: block; order: -1; }
  .brand { min-width: 0; }
  .app-shell { display: block; }
  .sidebar { width: 250px; height: calc(100vh - 68px); position: fixed; left: -270px; top: 68px; z-index: 40; box-shadow: var(--shadow); transition: .25s ease; }
  .sidebar.open { left: 0; }
  .main-content { padding: 25px 18px 45px; }
  .dashboard-grid, .detail-layout, .feature-split { grid-template-columns: 1fr; }
  .hero { padding-top: 55px; grid-template-columns: 1fr; }
  .hero-demo { min-height: 390px; }
  .hero-card { right: 0; left: 0; margin: auto; }
  .option-grid { grid-template-columns: repeat(2, 1fr); }
  .service-grid { grid-template-columns: 1fr; }
  .site-footer { grid-template-columns: 1fr; text-align: center; }
  .footer-brand { margin: auto; }
}

@media (max-width: 560px) {
  .top-actions .btn-ghost-light { display: none; }
  .brand { min-width: 150px; }
  .brand-mark { width: 36px; height: 36px; }
  .page-heading, .section-heading { align-items: flex-start; flex-direction: column; }
  .stats-grid, .form-grid, .form-grid-3, .option-grid, .process-grid { grid-template-columns: 1fr; }
  .request-row { grid-template-columns: 44px 1fr auto; }
  .request-cell { display: none; }
  .step { font-size: 0; }
  .form-card { padding: 21px; }
  .privacy-note { display: none; }
  .filter-bar { overflow-x: auto; }
  .filter-spacer { display: none; }
  .detail-kpis { grid-template-columns: repeat(2, 1fr); row-gap: 17px; }
  .detail-kpis span:nth-child(3) { padding-left: 0; border-left: 0; }
  .hero { padding: 45px 20px 55px; }
  .hero h1 { font-size: 39px; }
  .hero-actions { align-items: stretch; flex-direction: column; }
  .floating-one { left: -5px; }
  .floating-two { right: -5px; }
  .public-section { padding: 60px 20px; }
}
