:root {
  --petrol: #073b43;
  --petrol-2: #0a505a;
  --petrol-soft: #e8f1f1;
  --ink: #0a0c0d;
  --muted: #687277;
  --line: #dfe5e5;
  --paper: #f4f6f5;
  --white: #fff;
  --success: #0d7b5b;
  --warning: #b37714;
  --danger: #a93f3f;
  --shadow: 0 18px 50px rgba(6, 32, 36, .09);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: Inter, "Segoe UI", Arial, sans-serif; }
button, input, textarea, select { font: inherit; }
button { cursor: pointer; }

.app-shell { min-height: 100vh; display: grid; grid-template-columns: 250px 1fr; }
.sidebar { position: sticky; top: 0; height: 100vh; display: flex; flex-direction: column; padding: 24px 18px; color: white; background: #080b0c; }
.brand { color: white; text-decoration: none; display: flex; align-items: center; gap: 12px; letter-spacing: .12em; }
.brand-mark { display: grid; place-items: center; width: 42px; height: 42px; border: 1px solid #4d696d; color: white; background: var(--petrol); font: 800 22px Georgia, serif; }
.brand strong { display: block; font-size: 17px; }
.brand small { display: block; margin-top: 4px; color: #9ca7a9; font-size: 9px; letter-spacing: .18em; text-transform: uppercase; }
.main-nav { display: grid; gap: 5px; margin-top: 38px; }
.nav-item { border: 0; border-radius: 10px; padding: 10px 11px; color: #aab2b3; background: transparent; text-align: left; transition: .2s; font-size: 12px; line-height: 1.15; }
.nav-item span { display: inline-block; width: 23px; color: #7d898b; font-size: 15px; }
.nav-item:hover, .nav-item.active { color: white; background: var(--petrol); }
.nav-item.active span { color: #9fd0d3; }
.sidebar-footer { margin-top: auto; padding-top: 18px; color: #777f81; font-size: 10px; line-height: 1.5; }
.studio-status { display: flex; align-items: center; gap: 10px; margin-bottom: 0; color: white; }
.studio-status i { width: 8px; height: 8px; border-radius: 50%; background: #49c797; box-shadow: 0 0 0 5px rgba(73,199,151,.12); }
.studio-status span { font-size: 10px; text-transform: uppercase; letter-spacing: .08em; }
.studio-status small { display: block; margin-top: 3px; color: #757f81; font-size: 9px; text-transform: none; letter-spacing: .04em; }

.main { min-width: 0; }
.topbar { height: 100px; display: flex; align-items: center; justify-content: space-between; padding: 0 4vw; border-bottom: 1px solid var(--line); background: rgba(255,255,255,.88); backdrop-filter: blur(12px); }
.topbar h1 { margin: 2px 0 0; font: 600 25px Georgia, serif; }
.eyebrow { margin: 0; color: var(--petrol-2); font-size: 9px; font-weight: 800; letter-spacing: .2em; text-transform: uppercase; }
.eyebrow.light { color: #9bc6ca; }
.top-actions { display: flex; align-items: center; gap: 18px; }
.today { color: var(--muted); font-size: 12px; }
.mobile-menu { display: none; border: 0; background: none; font-size: 22px; }

.view { display: none; padding: 34px 4vw 60px; animation: fade .22s ease; }
.view.active { display: block; }
@keyframes fade { from { opacity: 0; transform: translateY(4px); } }
.hero { min-height: 300px; display: grid; grid-template-columns: 1.1fr .9fr; overflow: hidden; color: white; background: linear-gradient(125deg, #052e34, #0b4f58); box-shadow: var(--shadow); }
.hero-content { padding: 50px; position: relative; z-index: 2; }
.hero h2 { margin: 15px 0; font: 500 clamp(31px, 4vw, 50px)/1.05 Georgia, serif; }
.hero h2 em { color: #b7d5d7; font-weight: 400; }
.hero p:not(.eyebrow) { color: #c5d4d5; font-size: 13px; }
.hero-art { position: relative; overflow: hidden; background: radial-gradient(circle at 60% 45%, rgba(70,148,156,.48), transparent 35%), linear-gradient(135deg, #0b2023, #031416); }
.hero-art:after { content: ""; position: absolute; inset: 0; background: repeating-linear-gradient(115deg, transparent 0 28px, rgba(255,255,255,.018) 29px 30px); }
.hero-art > span { position: absolute; right: 40px; bottom: 28px; z-index: 2; text-align: right; color: rgba(255,255,255,.5); letter-spacing: .2em; font-size: 12px; }
.hero-art > span strong { color: white; font-size: 22px; }
.softbox { position: absolute; width: 75px; height: 100px; border: 5px solid #1d292b; background: linear-gradient(135deg,#fff,#bccdce); box-shadow: 0 0 45px rgba(215,255,255,.35); transform: skewY(-8deg); }
.softbox.one { top: 42px; left: 18%; }
.softbox.two { top: 30px; right: 13%; width: 58px; height: 82px; }
.camera-shape { position: absolute; left: 47%; top: 43%; width: 90px; height: 65px; border-radius: 8px; background: #050708; box-shadow: -25px 25px 0 -12px #050708; }
.camera-shape:after { content: ""; position: absolute; width: 42px; height: 42px; border: 8px solid #172b2e; border-radius: 50%; top: 5px; left: 18px; }
.btn { border: 0; padding: 13px 19px; border-radius: 5px; font-size: 12px; font-weight: 700; transition: .2s; }
.btn:hover { transform: translateY(-1px); filter: brightness(1.04); }
.btn.primary { color: white; background: var(--petrol); }
.btn.white { margin-top: 12px; color: var(--petrol); background: white; }
.btn.outline { color: var(--petrol); border: 1px solid #b7c7c8; background: white; }
.btn.compact { padding: 10px 14px; }
.btn.full { width: 100%; margin-top: 10px; }

.metrics { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; margin: 20px 0; }
.financial-result { display: grid; grid-template-columns: 1.1fr repeat(4,1fr); gap: 0; margin: 0 0 20px; border: 1px solid #164b8e; background: linear-gradient(100deg,#041020,#06234d); }
.financial-result > div, .financial-result > article { padding: 20px; border-right: 1px solid #173f6f; }
.financial-result article:last-child { border-right: 0; }
.result-heading h3 { margin: 6px 0 0; font: 600 18px Georgia,serif; }
.financial-result article span,.financial-result article small { display:block;color:var(--muted);font-size:9px; }
.financial-result article strong { display:block;margin:8px 0 5px;font:600 20px Georgia,serif; }
.financial-result .result-total { background:#0068f4; }
.financial-result .result-total span,.financial-result .result-total small { color:#d5e8ff; }
.metric { padding: 22px; border: 1px solid var(--line); background: white; }
.metric span { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .08em; }
.metric strong { display: block; margin: 10px 0 4px; font: 600 28px Georgia, serif; }
.metric small { color: var(--muted); font-size: 10px; }
.metric i { float: right; display: grid; place-items: center; width: 34px; height: 34px; border-radius: 50%; color: var(--petrol); background: var(--petrol-soft); font-style: normal; }
.dashboard-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 20px; }
.panel { border: 1px solid var(--line); background: white; box-shadow: 0 5px 25px rgba(0,0,0,.025); }
.span-2 { grid-column: span 2; }
.dashboard-grid .span-2 { grid-column: auto; }
.panel-head { display: flex; align-items: center; justify-content: space-between; padding: 22px 24px; border-bottom: 1px solid var(--line); }
.panel h3 { margin: 5px 0 0; font: 600 19px Georgia, serif; }
.link-button { border: 0; color: var(--petrol); background: none; font-size: 11px; font-weight: 700; }
.booking-row { display: grid; grid-template-columns: 64px 1fr auto auto; align-items: center; gap: 18px; padding: 17px 24px; border-bottom: 1px solid #edf0f0; }
.booking-row:last-child { border-bottom: 0; }
.date-tile { padding: 8px; color: var(--petrol); background: var(--petrol-soft); text-align: center; }
.date-tile strong { display: block; font-size: 20px; }
.date-tile small { font-size: 9px; text-transform: uppercase; }
.booking-row h4 { margin: 0 0 5px; font-size: 13px; }
.booking-row p { margin: 0; color: var(--muted); font-size: 10px; }
.booking-price { font-weight: 700; font-size: 12px; }
.badge { display: inline-block; padding: 6px 9px; border-radius: 20px; font-size: 9px; font-weight: 800; text-transform: uppercase; }
.badge.confirmada, .badge.pago, .badge.concluída { color: var(--success); background: #e7f5ef; }
.badge.pendente, .badge.parcial { color: var(--warning); background: #fff4dd; }
.badge.cancelada { color: var(--danger); background: #fae7e7; }
.empty { padding: 38px 24px; color: var(--muted); text-align: center; font-size: 12px; }
.finance-body { padding: 25px; }
.finance-ring { width: 155px; height: 155px; display: grid; place-items: center; margin: 5px auto 25px; border-radius: 50%; background: conic-gradient(var(--petrol) var(--progress), #dfeaea 0); position: relative; }
.finance-ring:after { content: ""; position: absolute; inset: 15px; border-radius: 50%; background: white; }
.finance-ring div { position: relative; z-index: 1; text-align: center; }
.finance-ring strong { display: block; font: 600 20px Georgia, serif; }
.finance-ring small { color: var(--muted); font-size: 9px; }
.finance-line { display: flex; justify-content: space-between; padding: 9px 0; border-top: 1px solid var(--line); font-size: 11px; }

.section-intro { display: flex; align-items: end; justify-content: space-between; margin-bottom: 25px; }
.section-intro h2 { margin: 6px 0; font: 600 29px Georgia, serif; }
.section-intro p:not(.eyebrow) { margin: 0; color: var(--muted); font-size: 12px; }
.reservation-number { padding: 12px 17px; border: 1px solid var(--line); color: var(--muted); background: white; font-size: 11px; }
.reservation-number strong { margin-left: 6px; color: var(--petrol); }
.form-layout { display: grid; grid-template-columns: minmax(0, 1fr) 350px; gap: 20px; align-items: start; }
.form-main { display: grid; gap: 18px; }
.form-card { padding: 27px; }
.card-title { display: flex; align-items: center; gap: 14px; margin-bottom: 22px; }
.card-title > span { display: grid; place-items: center; width: 34px; height: 34px; border-radius: 50%; color: white; background: var(--petrol); font-size: 10px; font-weight: 800; }
.card-title h3 { margin: 0; font: 600 18px Georgia, serif; }
.card-title p { margin: 3px 0 0; color: var(--muted); font-size: 10px; }
.field-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 17px; }
.field-grid.three { grid-template-columns: repeat(3, 1fr); }
.field { display: grid; gap: 7px; color: #445054; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; }
.field input, .field textarea, .field select, select { width: 100%; border: 1px solid #d7dede; border-radius: 4px; padding: 12px; outline: 0; color: var(--ink); background: white; font-size: 12px; font-weight: 400; text-transform: none; letter-spacing: 0; }
.field input:focus, .field textarea:focus, .field select:focus { border-color: var(--petrol-2); box-shadow: 0 0 0 3px rgba(10,80,90,.08); }
.duration-note { margin-top: 15px; padding: 10px 13px; color: var(--petrol); background: var(--petrol-soft); font-size: 10px; font-weight: 700; }
.form-aside { position: sticky; top: 18px; }
.package-card { padding: 25px; }
.packages { display: grid; gap: 9px; margin: 16px 0; }
.package-option { min-height: 67px; display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 11px; padding: 12px; border: 1px solid var(--line); border-radius: 4px; position: relative; cursor: pointer; }
.package-option:has(input:checked) { border: 2px solid var(--petrol); background: #f3f8f8; }
.package-option > i { position: absolute; right: 8px; top: -8px; padding: 3px 6px; color: white; background: var(--petrol); font-size: 7px; font-style: normal; letter-spacing: .1em; }
.package-option input { accent-color: var(--petrol); }
.package-option span b, .package-option span small { display: block; }
.package-option span b { font: 600 15px Georgia, serif; }
.package-option span small, .package-option strong small { margin-top: 3px; color: var(--muted); font-size: 9px; font-weight: 400; }
.package-option strong { text-align: right; font-size: 12px; }
.package-option strong small { display: inline; }
.package-option { overflow: visible; }
.package-option .package-copy em { display: block; margin-top: 5px; color: #8293a9; font-size: 8px; font-style: normal; line-height: 1.35; }
.package-option mark { position: absolute; right: 8px; top: -8px; z-index: 2; padding: 3px 6px; color: #fff; border: 0; background: #00a65a; font-size: 7px; font-weight: 800; letter-spacing: .1em; }
.package-option > .package-selected { position: absolute; right: -7px; top: -7px; display: none; width: 19px; height: 19px; place-items: center; padding: 0; border-radius: 50%; color: #fff; font-size: 10px; font-style: normal; }
.package-option:has(input:checked) > .package-selected { display: grid; }
.package-option.package-start { border-left: 4px solid #087cff; }
.package-option.package-start .package-copy b, .package-option.package-start > strong { color: #45a1ff; }
.package-option.package-start:has(input:checked) { border-color: #087cff; background: linear-gradient(100deg,#071d39,#041020); }
.package-option.package-start > .package-selected { background: #087cff; }
.package-option.package-pro { border-left: 4px solid #00b764; }
.package-option.package-pro .package-copy b, .package-option.package-pro > strong { color: #43dda0; }
.package-option.package-pro:has(input:checked) { border-color: #00b764; background: linear-gradient(100deg,#082c24,#041711); }
.package-option.package-pro > .package-selected { background: #00b764; }
.package-option.package-premium { border-left: 4px solid #ff9700; }
.package-option.package-premium .package-copy b, .package-option.package-premium > strong { color: #ffb43d; }
.package-option.package-premium:has(input:checked) { border-color: #ff9700; background: linear-gradient(100deg,#35230a,#1a1002); }
.package-option.package-premium > .package-selected { background: #ff9700; }
.hours-field > small { color: var(--muted); font-size: 8px; font-weight: 400; line-height: 1.4; text-transform: none; }
.hours-field { margin: 15px 0; }
.total-box { display: flex; align-items: end; justify-content: space-between; padding: 18px; color: white; background: var(--petrol); }
.total-box span { font-size: 10px; text-transform: uppercase; }
.total-box span small { display: block; margin-top: 5px; color: #b9d1d3; text-transform: none; }
.total-box strong { font: 600 21px Georgia, serif; }
.package-card > .field { margin-top: 15px; }

.calendar-head { display: flex; align-items: center; justify-content: center; gap: 30px; padding: 20px; border-bottom: 1px solid var(--line); }
.calendar-head h3 { min-width: 180px; margin: 0; text-align: center; text-transform: capitalize; }
.icon-btn { width: 34px; height: 34px; border: 1px solid var(--line); color: var(--petrol); background: white; }
.calendar { display: grid; grid-template-columns: repeat(7, 1fr); }
.calendar .weekday { padding: 11px; color: var(--muted); background: #f7f9f8; text-align: center; font-size: 9px; font-weight: 800; text-transform: uppercase; }
.calendar-day { min-height: 110px; padding: 10px; border-top: 1px solid var(--line); border-right: 1px solid var(--line); }
.calendar-day.muted { color: #b8bfc0; background: #fafbfb; }
.calendar-day.today-day .day-number { display: grid; place-items: center; width: 25px; height: 25px; margin: -4px 0 2px -4px; border-radius: 50%; color: white; background: var(--petrol); }
.day-number { font-size: 10px; font-weight: 700; }
.calendar-booking { margin-top: 6px; padding: 5px 6px; border-left: 3px solid var(--petrol); color: var(--petrol); background: var(--petrol-soft); font-size: 8px; line-height: 1.4; }
.search { min-width: 230px; display: flex; align-items: center; gap: 8px; padding: 0 13px; border: 1px solid var(--line); background: white; }
.search input { width: 100%; border: 0; padding: 12px 0; outline: 0; font-size: 11px; }
.filter-row { display: flex; justify-content: space-between; gap: 10px; margin-bottom: 15px; }
.filter-row select { width: 180px; padding: 10px; }
.table-panel { overflow-x: auto; overflow-y: visible; }
.data-table { min-width: 760px; }
.table-row { display: grid; grid-template-columns: 1.4fr .8fr .9fr .8fr .8fr .35fr; align-items: center; gap: 14px; padding: 15px 20px; border-bottom: 1px solid var(--line); font-size: 11px; }
.table-row.client-row { grid-template-columns: 1.5fr 1fr 1.2fr .6fr; }
.table-row.fixed-contract-row, .table-row.marketing-row { grid-template-columns: 1.4fr 1fr .8fr .7fr .7fr; }
.table-row.marketing-row.task-warning { background: linear-gradient(90deg, rgba(255,151,0,.10), transparent 55%); }
.table-row.marketing-row.task-danger { background: linear-gradient(90deg, rgba(255,86,86,.14), transparent 55%); }
.table-row.marketing-row.task-completed { opacity: .78; background: linear-gradient(90deg, rgba(92,224,166,.08), transparent 55%); }
.task-timebar { position: relative; height: 7px; margin-top: 8px; overflow: hidden; border-radius: 999px; background: rgba(255,255,255,.08); }
.task-timebar i { position: absolute; inset: 0 auto 0 0; width: var(--progress); border-radius: inherit; background: linear-gradient(90deg,#00b764,#ff9700,#ff3838); animation: taskPulse 1.5s ease-in-out infinite; }
.task-timebar.safe i { background: #00b764; animation-duration: 2.2s; }
.task-timebar.warning i { background: linear-gradient(90deg,#00b764,#ff9700); animation-duration: 1.5s; }
.task-timebar.danger i { background: linear-gradient(90deg,#ff9700,#ff3838); animation-duration: .9s; }
.task-time-label { display: block; margin-top: 5px; color: #ffbd59 !important; font-weight: 800; }
.task-danger .task-time-label { color: #ff8585 !important; }
.task-time-label.completed { color: #5ce0a6 !important; }
@keyframes taskPulse { 0%,100%{filter:brightness(1);opacity:.82} 50%{filter:brightness(1.45);opacity:1} }
.table-row.head { color: var(--muted); background: #f7f9f8; font-size: 8px; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; }
.table-row strong { display: block; margin-bottom: 3px; font-size: 11px; }
.table-row small { color: var(--muted); }
.table-actions { position: relative; }
.more-btn { border: 0; background: none; font-weight: 800; }
.action-menu { position: fixed; right: auto; z-index: 1000; min-width: 210px; max-width: calc(100vw - 24px); padding: 8px; border: 1px solid var(--line); background: white; box-shadow: var(--shadow); border-radius: 14px; }
.action-menu button { width: 100%; border: 0; padding: 9px; background: white; text-align: left; font-size: 10px; }
.action-menu button:hover { background: var(--petrol-soft); }
.report-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.report-card { padding: 24px; }
.report-card.wide { grid-column: span 2; }
.report-card h3 { margin-bottom: 22px; }
.bar-row { display: grid; grid-template-columns: 70px 1fr 80px; align-items: center; gap: 12px; margin: 14px 0; font-size: 10px; }
.bar-track { height: 8px; background: #edf1f1; }
.bar-fill { height: 100%; background: var(--petrol); }
.stat-big { font: 600 35px Georgia, serif; color: var(--petrol); }
.stat-label { color: var(--muted); font-size: 10px; }

.modal { position: fixed; inset: 0; z-index: 50; display: none; align-items: flex-start; justify-content: center; padding: 30px; overflow-y: auto; }
.modal.open { display: flex; }
.modal-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,.72); backdrop-filter: blur(5px); }
.modal-window { width: min(900px, 100%); position: relative; z-index: 1; }
.modal-toolbar { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; padding: 12px 15px; background: white; }
.modal-toolbar small { display: block; color: var(--muted); font-size: 9px; }
.print-sheet { width: 210mm; min-height: 297mm; margin: auto; padding: 14mm 15mm 11mm; color: #0b0d0e; background: white; box-shadow: 0 10px 45px rgba(0,0,0,.3); font-family: Arial, sans-serif; }
.print-header { display: flex; justify-content: space-between; align-items: center; padding-bottom: 8mm; border-bottom: 2px solid var(--petrol); }
.print-logo { display: flex; align-items: center; gap: 10px; }
.print-logo .brand-mark { width: 35px; height: 35px; }
.print-logo strong { display: block; letter-spacing: .14em; }
.print-logo small { color: #607073; font-size: 7px; letter-spacing: .18em; }
.print-title { text-align: right; }
.print-title h1 { margin: 0; color: var(--petrol); font: 600 21px Georgia, serif; }
.print-title p { margin: 4px 0 0; color: #667174; font-size: 8px; }
.print-hero { margin: 6mm 0; padding: 5mm; color: white; background: var(--petrol); }
.print-hero p { margin: 0 0 2mm; color: #b9d5d7; font-size: 7px; text-transform: uppercase; letter-spacing: .15em; }
.print-hero strong { font: 500 17px Georgia, serif; }
.print-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4mm; }
.print-section { padding: 4mm; border: 1px solid #d7dfdf; }
.print-section.full { grid-column: 1 / -1; }
.print-section h2 { margin: 0 0 3mm; padding-bottom: 2mm; border-bottom: 1px solid #dfe5e5; color: var(--petrol); font-size: 8px; letter-spacing: .12em; text-transform: uppercase; }
.print-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 3mm; }
.print-field.full { grid-column: 1/-1; }
.print-field span { display: block; margin-bottom: 1mm; color: #788285; font-size: 6px; text-transform: uppercase; }
.print-field strong { font-size: 8px; line-height: 1.35; }
.print-total { display: flex; justify-content: space-between; align-items: center; margin-top: 4mm; padding: 4mm; color: white; background: #0b0e0f; }
.print-total span { font-size: 7px; text-transform: uppercase; }
.print-total strong { font: 600 18px Georgia, serif; }
.banking { margin-top: 4mm; padding: 4mm; background: #f0f5f5; font-size: 7px; line-height: 1.7; }
.print-message { margin: 5mm 0; text-align: center; color: var(--petrol); }
.print-message strong { display: block; font: 500 14px Georgia, serif; }
.print-message p { margin: 2mm 0 0; font-size: 8px; line-height: 1.5; }
.print-footer { display: grid; grid-template-columns: 1fr 1.6fr; gap: 5mm; padding-top: 4mm; border-top: 1px solid #cdd6d6; color: #536063; font-size: 6.5px; line-height: 1.6; }
.toast { position: fixed; right: 25px; bottom: 25px; z-index: 100; padding: 14px 18px; color: white; background: #0b0e0f; box-shadow: var(--shadow); font-size: 11px; opacity: 0; transform: translateY(10px); pointer-events: none; transition: .25s; }
.toast.show { opacity: 1; transform: translateY(0); }

@media (max-width: 1050px) {
  .app-shell { grid-template-columns: 78px 1fr; }
  .sidebar { padding: 25px 12px; align-items: center; }
  .brand > span:last-child, .nav-item:not(.active)::after, .nav-item { font-size: 0; }
  .nav-item span { width: auto; font-size: 19px; }
  .nav-item { width: 50px; text-align: center; }
  .sidebar-footer { display: none; }
  .form-layout { grid-template-columns: 1fr 315px; }
}
@media (max-width: 800px) {
  .app-shell { display: block; }
  .sidebar { position: fixed; left: -260px; z-index: 40; width: 250px; align-items: stretch; transition: .25s; }
  .sidebar.open { left: 0; }
  .brand > span:last-child { display: block; }
  .nav-item { width: 100%; font-size: 12px; text-align: left; }
  .nav-item span { width: 26px; }
  .mobile-menu { display: block; }
  .topbar { padding: 0 20px; }
  .today { display: none; }
  .hero { grid-template-columns: 1fr; }
  .hero-art { display: none; }
  .metrics { grid-template-columns: 1fr 1fr; }
  .dashboard-grid, .form-layout, .report-grid { grid-template-columns: 1fr; }
  .report-card.wide { grid-column: auto; }
  .form-aside { position: static; }
  .field-grid.three { grid-template-columns: 1fr; }
}
@media (max-width: 520px) {
  .view { padding: 24px 15px 40px; }
  .top-actions .btn { display: none; }
  .hero-content { padding: 35px 25px; }
  .metrics { grid-template-columns: 1fr; }
  .field-grid { grid-template-columns: 1fr; }
  .span-2 { grid-column: auto; }
  .section-intro { align-items: flex-start; gap: 15px; flex-direction: column; }
  .booking-row { grid-template-columns: 50px 1fr; }
  .booking-price, .booking-row > .badge { display: none; }
  .calendar-day { min-height: 75px; padding: 5px; }
  .calendar-booking { overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
  .modal { padding: 8px; }
  .modal-toolbar { flex-direction: column; gap: 10px; align-items: stretch; }
  .print-sheet { transform-origin: top left; transform: scale(.47); margin-bottom: -155mm; }
}

@media print {
  @page { size: A4; margin: 0; }
  body { background: white; }
  body * { visibility: hidden !important; }
  #printSheet, #printSheet * { visibility: visible !important; }
  #printSheet { position: absolute; left: 0; top: 0; width: 210mm; height: 297mm; min-height: 297mm; margin: 0; padding: 14mm 15mm 11mm; box-shadow: none; overflow: hidden; transform: none; }
}

/* Identidade oficial Korban Cine-TV — baseada na apresentação do Studio */
:root {
  --petrol: #0068f4;
  --petrol-2: #1682ff;
  --petrol-soft: #0a203d;
  --ink: #f7f9ff;
  --muted: #91a2b8;
  --line: #17345b;
  --paper: #020812;
  --success: #00b764;
  --warning: #ff9700;
  --danger: #ff5656;
  --shadow: 0 18px 50px rgba(0, 0, 0, .32);
}

.sidebar {
  background: linear-gradient(180deg, #020711, #00040a);
  border-right: 1px solid #0b4da1;
}
.brand img { display: block; width: 180px; height: auto; }
.nav-item:hover,
.nav-item.active {
  background: linear-gradient(90deg, #004cae, #006cf0);
  box-shadow: 0 6px 24px rgba(0,104,244,.18);
}
.nav-item.active span { color: #fff; }
.topbar { background: rgba(3,10,22,.92); }
.mobile-menu { color: #fff; }

.hero {
  min-height: 320px;
  grid-template-columns: .95fr 1.25fr;
  border: 1px solid #075dc9;
  background: linear-gradient(125deg, #020812, #061a38);
}
.hero h2 em { color: #1682ff; }
.hero p:not(.eyebrow) { color: #bfcee2; }
.hero-art {
  background-image:
    linear-gradient(90deg, #061a38 0%, rgba(2,8,18,.2) 38%, rgba(2,8,18,.02)),
    url("assets/landing/studio-real.jpg");
  background-size: cover;
  background-position: center 30%;
  background-repeat: no-repeat;
}
.hero-art::after {
  border-left: 1px solid rgba(22,130,255,.5);
  background: linear-gradient(90deg, rgba(2,8,18,.42), transparent 40%);
}
.hero-logo {
  position: absolute;
  z-index: 3;
  top: 18px;
  right: 25px;
  width: 145px;
  height: auto;
  filter: drop-shadow(0 4px 12px rgba(0,0,0,.65));
}
.softbox, .camera-shape, .hero-art > span { display: none; }

.panel,
.metric {
  border-color: var(--line);
  background: linear-gradient(145deg, #071321, #040c17);
  box-shadow: 0 10px 28px rgba(0,0,0,.2);
}
.metric i,
.date-tile {
  color: #72b5ff;
  border-color: #174d91;
  background: var(--petrol-soft);
}
.badge.confirmada, .badge.confirmado, .badge.pago, .badge.concluída, .badge.concluido { color: #43dda0; background: #082c24; }
.badge.pendente, .badge.parcial, .badge.em-andamento { color: #ffb43d; background: #31210b; }
.badge.cancelada { color: #ff8585; background: #351318; }
.finance-ring::after { background: #071321; }
.reservation-number,
.search { background: #071321; }
.search input { color: #fff; background: transparent; }

.field input,
.field textarea,
.field select,
select {
  color: #f7f9ff;
  border-color: #244261;
  background: #020914;
  color-scheme: dark;
}
.package-option:has(input:checked) {
  border-color: #1682ff;
  background: #071d39;
  box-shadow: 0 0 20px rgba(0,104,244,.12);
}
.package-option.recommended:has(input:checked) { border-color: #00b764; }
.package-option.recommended > i { background: #00a65a; }
.package-option:last-child:has(input:checked) { border-color: #ff9700; }
.total-box {
  border: 1px solid #1682ff;
  background: linear-gradient(100deg, #003e91, #006cf0);
}
.calendar .weekday,
.table-row.head { background: #050e1b; }
.calendar-day.muted { color: #46566c; background: #020710; }
.calendar-booking { color: #80bcff; background: var(--petrol-soft); }
.calendar-legend { display: flex; flex-wrap: wrap; gap: 18px; padding: 12px 20px; border-bottom: 1px solid var(--line); color: var(--muted); font-size: 9px; text-transform: uppercase; }
.calendar-legend span { display: flex; align-items: center; gap: 6px; }
.legend-dot { width: 9px; height: 9px; border-radius: 2px; }
.legend-dot.confirmed { background: #0068f4; }
.legend-dot.pending { background: #ff9700; }
.legend-dot.completed { background: #00b764; }
.legend-dot.payment { border: 2px solid #ff5656; background: transparent; }
.legend-dot.external { background: #8d5cff; }
.calendar-booking { display: grid; gap: 2px; border-left-width: 4px; }
.calendar-booking strong { color: #fff; font-size: 8px; }
.calendar-booking span { overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.calendar-booking small { color: #ffb4b4; font-size: 7px; font-weight: 800; text-transform: uppercase; }
.calendar-booking.status-confirmada { border-left-color: #1682ff; background: #082a56; }
.calendar-booking.status-pendente { border-left-color: #ff9700; background: #35230a; color: #ffc365; }
.calendar-booking.status-concluida { border-left-color: #00b764; background: #082c24; color: #65e2ac; }
.calendar-booking.payment-open { box-shadow: inset 0 0 0 1px rgba(255,86,86,.72); }
.calendar-booking.external-event { border-left-color: #8d5cff; background: #211343; color: #cbb8ff; }
.calendar-booking.external-event.status-confirmado { border-left-color:#1682ff;background:#082a56; }
.calendar-booking.external-event.status-em-andamento { border-left-color:#ff9700;background:#35230a; }
.calendar-booking.external-event.status-concluido { border-left-color:#00b764;background:#082c24; }
.payment-warning-text { color: #ff9b9b !important; font-weight: 800; }
.same-day-alert { display: grid; gap: 6px; margin-top: 12px; padding: 13px; border: 1px solid #ff9700; color: #ffd28b; background: #2d1d08; font-size: 10px; }
.same-day-alert strong { color: #fff; }
.same-day-alert span { display: block; padding: 5px 0; border-top: 1px solid rgba(255,255,255,.08); }
.same-day-alert b { float: right; color: #ff8d8d; text-transform: uppercase; }
.same-day-alert i { float: right; color: #5ce0a6; font-style: normal; }
.same-day-alert small { color: #ffb4b4; font-weight: 800; }
.action-menu,
.action-menu button { color: #fff; background: #071321; }
.action-menu button:disabled { color: #65758b; cursor: not-allowed; }
.action-menu .danger-action { color: #ff8585; }
.bar-track { background: #13263d; }

/* A ficha continua clara para impressão, com cabeçalho oficial escuro. */
.print-sheet { color: #0b0d0e; background: #fff; }
.print-header { border-color: #0068f4; }
.print-logo-box {
  display: grid;
  place-items: center;
  width: 43mm;
  height: 15mm;
  padding: 2mm;
  background: #020812;
}
.print-logo-box img { display: block; width: 39mm; height: auto; }
.print-logo > span:last-child { color: #101820; }
.print-logo > span:last-child strong { letter-spacing: .08em; }
.print-title h1,
.print-section h2,
.print-message { color: #005bd8; }
.print-hero { background: linear-gradient(90deg, #020812, #004fb7); }
.banking { color: #0b0d0e; background: #eef5ff; }

@media (max-width: 1050px) {
  .brand img { width: 50px; }
}
@media (max-width: 800px) {
  .brand img { width: 180px; }
}
@media (max-width: 520px) {
  .hero { grid-template-columns: 1fr; }
}

/* Login e controle de acesso */
.is-hidden { display: none !important; }
.login-screen {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1.25fr .75fr;
  color: #fff;
  background: #020812;
}
.login-visual {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: clamp(35px, 5vw, 75px);
  position: relative;
  overflow: hidden;
  background-image:
    linear-gradient(90deg, rgba(2,8,18,.96) 0%, rgba(2,8,18,.56) 50%, rgba(2,8,18,.16)),
    linear-gradient(0deg, rgba(2,8,18,.88), transparent 52%),
    url("assets/landing/studio-real.jpg");
  background-size: cover;
  background-position: center;
}
.login-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  border: 1px solid rgba(0,104,244,.45);
  pointer-events: none;
}
.login-logo { width: min(280px, 54%); position: relative; z-index: 1; }
.login-copy { max-width: 550px; position: relative; z-index: 1; }
.login-copy h1 { margin: 12px 0; font: 600 clamp(45px, 6vw, 80px)/.95 Georgia, serif; }
.login-copy > p:last-child { color: #c0d1e8; font-size: 16px; }
.login-panel {
  display: grid;
  place-items: center;
  padding: 35px;
  background:
    radial-gradient(circle at 50% 30%, rgba(0,104,244,.16), transparent 35%),
    #020711;
}
.login-card { width: min(390px, 100%); padding: 38px; border: 1px solid #164b8e; background: rgba(5,15,29,.94); box-shadow: 0 25px 80px rgba(0,0,0,.45); }
.login-card h2 { margin: 8px 0; font: 600 33px Georgia, serif; }
.login-card > p:not(.eyebrow) { margin: 0 0 28px; color: var(--muted); font-size: 12px; }
.login-card .field { margin-top: 18px; }
.login-error { min-height: 18px; margin-top: 12px; color: #ff8585; font-size: 11px; }
.login-help { display: block; margin-top: 18px; color: var(--muted); text-align: center; line-height: 1.5; }
.user-menu {
  display: grid;
  grid-template-columns: 34px auto;
  grid-template-rows: auto auto;
  column-gap: 9px;
  border: 0;
  color: #fff;
  background: transparent;
  text-align: left;
}
.user-menu > span { grid-row: 1 / 3; display: grid; place-items: center; width: 34px; height: 34px; border-radius: 50%; background: #0068f4; font-size: 10px; font-weight: 800; }
.user-menu b { align-self: end; font-size: 10px; }
.user-menu small { color: var(--muted); font-size: 8px; }
.logout-button { width: 34px; height: 34px; border: 1px solid var(--line); color: #9fb3cb; background: transparent; }
.users-layout { display: grid; grid-template-columns: minmax(350px,.7fr) 1.3fr; gap: 20px; align-items: start; }
.users-layout .btn { margin-top: 20px; }
.users-table { min-width: 600px; }
.table-row.user-row { grid-template-columns: 1.5fr .8fr .65fr 1fr; }
.user-actions { display: flex; flex-wrap: wrap; gap: 4px; }
.user-actions .link-button { padding: 5px; }
.user-role-select { width: 100%; min-width: 145px; padding: 7px; border: 1px solid #244261; color: #fff; background: #020914; font-size: 9px; }
.nav-alert { min-width: 20px; margin-left: auto; padding: 3px 6px; border-radius: 12px; color: #fff; background: #e32636; font-size: 8px; text-align: center; box-shadow: 0 0 14px rgba(227,38,54,.7); }
.nav-item.has-alert { color: #fff; border-color: #e32636; background: rgba(227,38,54,.16); }
.request-popup { position: fixed; right: 22px; bottom: 22px; z-index: 1200; width: min(380px,calc(100vw - 30px)); padding: 22px; border: 1px solid #e32636; color: #fff; background: #071321; box-shadow: 0 20px 70px rgba(0,0,0,.65); }
.request-popup > button:first-child { position: absolute; top: 8px; right: 10px; border: 0; color: #9fb3cb; background: transparent; font-size: 22px; }
.request-popup > span { color: #ff6571; font-size: 9px; font-weight: 900; letter-spacing: .12em; }
.request-popup strong { display: block; margin: 8px 25px 5px 0; font-size: 17px; }
.request-popup p { color: #bfd0e5; font-size: 10px; line-height: 1.5; }
.asset-overview { min-width: 155px; padding: 10px 15px; border: 1px solid #1682ff; background: #071d39; text-align: center; }
.asset-overview span { display: block; color: #80bcff; font-size: 8px; font-weight: 800; }
.asset-overview strong { display: block; margin-top: 3px; color: #fff; font-size: 22px; }
.dashboard-period{display:flex;flex-wrap:wrap;align-items:end;gap:12px;margin:0 0 20px;padding:15px;border:1px solid #164b8e;background:#041020}.dashboard-period label{display:grid;gap:6px;color:#80bcff;font-size:8px;font-weight:800;text-transform:uppercase}.dashboard-period select,.dashboard-period input{min-width:145px;padding:10px;border:1px solid #244261;color:#fff;background:#020914}.admin-financial-alert{padding:13px;border:1px solid #ff9700;color:#ffd28b;background:#2d1d08;font-size:10px;font-weight:800}.checkbox-field{display:flex!important;align-items:center;gap:10px;padding:13px;border:1px solid #174d91;background:#071d39}.checkbox-field input{width:auto!important}.non-sequential-box{padding:15px;border:1px solid #174d91;background:#030b17}.non-sequential-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;color:#80bcff;font-size:9px;font-weight:800}.event-date-row{display:grid;grid-template-columns:1fr 1fr auto;gap:8px;margin-top:8px}.event-date-row input{padding:10px;border:1px solid #244261;color:#fff;background:#020914}.event-date-row button{border:1px solid #7d2730;color:#ff8585;background:#351318}.calendar-booking{cursor:pointer}.detail-window{max-width:760px}.detail-content{padding:28px}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.detail-grid div{padding:13px;border:1px solid #17345b;background:#030b17}.detail-grid span,.detail-grid strong{display:block}.detail-grid span{color:#80bcff;font-size:8px;text-transform:uppercase}.detail-grid strong{margin-top:6px;font-size:12px}.detail-grid .full{grid-column:1/-1}.payment-alerts{display:grid;gap:8px;margin:0 0 20px}.payment-alert{padding:14px;border:1px solid #ff5656;color:#ffd0d0;background:#351318;font-size:10px}.payment-alert strong{color:#fff}.proof-warning{color:#ff8585!important;font-weight:800}.payment-confirmed{color:#5ce0a6!important}
.client-form-card { margin-bottom: 18px; }
.form-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 18px; }
.form-actions .btn { margin-top: 0; }
.partial-payment { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 15px; }
.balance-box { display: grid; align-content: center; padding: 12px; border: 1px solid #ff9700; background: #2d1d08; }
.balance-box span { color: #ffbd59; font-size: 8px; text-transform: uppercase; }
.balance-box strong { margin: 4px 0; color: #fff; font-size: 17px; }
.balance-box small { color: #ffce84; font-size: 8px; }
.attachment-field small { color: var(--muted); font-size: 8px; font-weight: 400; text-transform: none; }
.attachment-list { display: grid; gap: 5px; margin-top: 8px; }
.attachment-chip { display: flex; align-items: center; gap: 8px; padding: 8px; border: 1px solid #244261; color: #d5e4f7; background: #061323; font-size: 9px; }
.attachment-chip span { flex: 1; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.attachment-chip a, .attachment-chip button { border: 0; color: #67adff; background: none; font-size: 9px; }
.team-picker { display: grid; grid-template-columns: repeat(auto-fit,minmax(180px,1fr)); gap: 8px; margin-top: 10px; }
.team-picker-option { display: grid; grid-template-columns: auto 1fr; gap: 6px 9px; align-items: center; padding: 10px; border-radius: 16px; border: 1px solid rgba(22,130,255,.34); background: rgba(3,15,31,.72); cursor: pointer; transition: transform .18s ease, border-color .18s ease, background .18s ease; }
.team-picker-option:hover { transform: translateY(-1px); border-color: #1682ff; background: rgba(8,124,255,.13); }
.team-picker-option input { width: 16px !important; height: 16px; accent-color: #1682ff; }
.team-picker-option span { color: #fff; font-size: 10px; font-weight: 800; }
.team-picker-option small { grid-column: 2; color: #80bcff; font-size: 8px; text-transform: none; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.hours-error { margin-top: 12px; padding: 10px; border: 1px solid #ff5656; color: #ffadad; background: #351318; font-size: 9px; font-weight: 800; }
.btn:disabled { opacity: .42; cursor: not-allowed; transform: none; }
.row-actions { display: flex; flex-wrap: wrap; gap: 5px; }
.success-text { color: #5ce0a6 !important; }
.danger-text { color: #ff8585 !important; }
.asset-layout, .external-layout { display: grid; grid-template-columns: minmax(340px,.8fr) 1.2fr; gap: 20px; align-items: start; }
.asset-cards, .external-cards { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 14px; }
.asset-card { overflow: hidden; }
.asset-card > img { width: 100%; height: 180px; object-fit: cover; background: #020711; }
.asset-card-body { padding: 18px; }
.asset-card-body h3 { margin: 12px 0 6px; font-family: Arial,sans-serif; }
.asset-card-body p { min-height: 32px; color: var(--muted); font-size: 9px; line-height: 1.5; }
.asset-tag { display: inline-block; margin-right: 5px; padding: 6px 8px; color: #fff; border: 1px solid #1682ff; background: #003e91; font-size: 9px; font-weight: 800; }
.asset-photo-preview { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; margin-top: 10px; }
.asset-photo-preview img { width: 90px; height: 65px; object-fit: cover; border: 1px solid #1682ff; }
.asset-photo-preview small { color: var(--muted); }
.equipment-selector { margin-top: 20px; }
.event-equipment-tools { display: grid; grid-template-columns: 1fr 190px; gap: 12px; margin: 12px 0; }
.event-equipment-workspace { display: grid; grid-template-columns: minmax(0,1fr) 250px; gap: 12px; align-items: start; }
#eventEquipmentList { max-height: 310px; display: grid; gap: 7px; margin-top: 12px; overflow-y: auto; }
.equipment-check { display: grid; grid-template-columns: auto 52px 1fr; align-items: center; gap: 10px; padding: 8px; border: 1px solid #17345b; background: #030b17; cursor: pointer; }
.equipment-check { grid-template-columns: auto 52px 1fr 70px; }
.equipment-check.unavailable { opacity:.45;cursor:not-allowed; }
.equipment-qty { width:100%;padding:8px;border:1px solid #244261;color:#fff;background:#020914; }
.equipment-date-warning { margin-top:12px;padding:13px;border:1px solid #ff9700;color:#ffd28b;background:#2d1d08;font-size:10px; }
.equipment-check:has(input:checked) { border-color: #1682ff; background: #071d39; }
.equipment-check input { accent-color: #0068f4; }
.equipment-check img { width: 52px; height: 42px; object-fit: cover; }
.equipment-check strong, .equipment-check small { display: block; }
.equipment-check strong { font-size: 9px; }
.equipment-check small { margin-top: 4px; color: var(--muted); font-size: 8px; }
.event-equipment-preview { position: sticky; top: 92px; min-height: 180px; padding: 14px; border: 1px solid rgba(22,130,255,.35); border-radius: 16px; background: linear-gradient(180deg,rgba(8,26,48,.95),rgba(2,8,18,.95)); box-shadow: var(--shadow); }
.event-equipment-preview > div:first-child { display: flex; justify-content: space-between; align-items: center; gap: 10px; margin-bottom: 10px; }
.event-equipment-preview strong { color: #fff; font-size: 10px; }
#eventEquipmentPreview { display: grid; gap: 7px; max-height: 335px; overflow-y: auto; }
.preview-equipment-row { display: grid; grid-template-columns: 42px 1fr 25px; align-items: center; gap: 8px; padding: 7px; border-radius: 12px; background: rgba(255,255,255,.045); }
.preview-equipment-row img { width: 42px; height: 36px; object-fit: cover; border-radius: 8px; background: #020914; }
.preview-equipment-row span, .preview-equipment-row small { display: block; min-width: 0; }
.preview-equipment-row strong { font-size: 9px; }
.preview-equipment-row small { margin-top: 3px; color: var(--muted); font-size: 7.5px; line-height: 1.25; }
.preview-equipment-row button { width: 25px; height: 25px; border: 0; border-radius: 50%; color: #fff; background: rgba(255,82,82,.28); cursor: pointer; }
.empty.compact { padding: 12px; font-size: 9px; }
.external-side-panel { min-width: 0; position: sticky; top: 16px; align-self: start; z-index: 5; }
.external-note-preview {
  position: sticky;
  top: 16px;
  min-height: 620px;
  max-height: calc(100vh - 120px);
  display: flex;
  flex-direction: column;
  padding: 24px;
  border-radius: 28px;
  background:
    radial-gradient(circle at 90% 0%, rgba(0,104,244,.24), transparent 28%),
    linear-gradient(145deg, rgba(8,26,48,.98), rgba(2,8,18,.98));
  box-shadow: var(--shadow);
}
.note-preview-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 18px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(22,130,255,.25);
}
.note-preview-head h3 { margin: 4px 0 6px; color: #fff; font-family: Arial,sans-serif; font-size: 22px; }
.note-preview-head small { color: var(--muted); font-size: 10px; line-height: 1.45; }
.note-preview-head > strong { flex: 0 0 auto; padding: 10px 12px; border-radius: 999px; color: #fff; background: #0068f4; font-size: 11px; }
.note-preview-client { display: grid; grid-template-columns: 1fr; gap: 9px; margin: 16px 0; padding: 14px; border-radius: 18px; background: rgba(255,255,255,.045); }
.note-preview-client span { display: block; margin-bottom: 4px; color: #80bcff; font-size: 8px; font-weight: 800; text-transform: uppercase; letter-spacing: .12em; }
.note-preview-client strong { display: block; color: #fff; font-size: 11px; line-height: 1.35; }
.note-preview-list-head,
#eventEquipmentPreview .preview-equipment-row {
  display: grid;
  grid-template-columns: 70px 1.35fr 1.1fr 88px;
  align-items: center;
  gap: 12px;
}
.note-preview-list-head { padding: 0 12px 9px; color: #80bcff; font-size: 8px; font-weight: 900; text-transform: uppercase; letter-spacing: .12em; }
#eventEquipmentPreview { flex: 1; display: grid; align-content: start; gap: 9px; max-height: none; overflow-y: auto; padding-right: 4px; }
#eventEquipmentPreview .preview-equipment-row { padding: 11px 12px; border-radius: 18px; background: rgba(255,255,255,.055); }
#eventEquipmentPreview .preview-equipment-row img { width: 70px; height: 54px; border-radius: 14px; }
#eventEquipmentPreview .preview-equipment-row strong { color: #fff; font-size: 11px; line-height: 1.25; }
#eventEquipmentPreview .preview-equipment-row small { color: var(--muted); font-size: 9px; line-height: 1.45; }
#eventEquipmentPreview .preview-equipment-row button {
  width: 100%;
  height: auto;
  padding: 9px 8px;
  border-radius: 12px;
  color: #fff;
  background: rgba(255,82,82,.3);
  font-size: 8px;
  font-weight: 900;
  text-transform: uppercase;
}
.external-cards { grid-template-columns: 1fr; }
.external-card { padding: 20px; }
.external-card h3 { margin: 5px 0; }
.external-card p, .external-card small { color: var(--muted); font-size: 9px; }
.external-equipment { display: flex; flex-wrap: wrap; gap: 5px; margin: 14px 0; }
.quotes-layout { display: grid; grid-template-columns: minmax(360px,.85fr) 1.15fr; gap: 20px; align-items: start; }
.table-row.quote-row { grid-template-columns: 1.25fr 1fr .7fr .65fr .75fr; }
.quote-table { display: grid; gap: 1.1mm; }
.quote-table.page-continuation,
.exit-table.page-continuation { break-before: page; page-break-before: always; margin-top: 0; }
.quote-table-row { display: grid; grid-template-columns: 12mm 16mm 1fr 25mm; gap: 2mm; align-items: center; padding: 1.5mm 2mm; border-radius: 8px; color: #f7f9ff; background: rgba(2,8,18,.32); font-size: 8px; }
.quote-table-head { color: #80bcff; background: rgba(8,124,255,.22); font-weight: 900; text-transform: uppercase; letter-spacing: .08em; }
.quote-note .print-grid { gap: 3mm; }
.quote-note .quote-items { max-height: none; overflow: visible; }
.quote-note .print-total { margin-top: 2mm; }
.quote-note .quote-discount { background: linear-gradient(135deg,#23364e,#162235) !important; }
.quote-asset-picker > span { color:#80bcff;font-size:8px;font-weight:900;text-transform:uppercase;letter-spacing:.1em; }
.compact-field input { padding: 9px 10px; font-size: 11px; }
.compact-field small { font-size: 8px; }
.quote-asset-tools { display:grid;grid-template-columns:1fr auto;gap:8px;margin-top:7px; }
.quote-asset-tools input { width:100%;border:1px solid #244261;border-radius:15px;padding:12px;color:#f8fbff;background:#020914; }
.quote-selected-assets,.quote-linked-assets { display:flex;flex-wrap:wrap;gap:7px;margin-top:10px; }
.quote-selected-assets span,.quote-linked-assets span { display:inline-flex;align-items:center;gap:7px;padding:7px 9px;border-radius:999px;color:#fff;background:rgba(8,124,255,.22);font-size:9px;font-weight:800; }
.quote-selected-assets button { border:0;border-radius:50%;width:18px;height:18px;color:#fff;background:rgba(255,82,82,.55); }
.quote-items-editor { display:grid; gap:7px; margin-top:10px; }
.quote-item-chip { display:grid; grid-template-columns:auto 82px 82px 1fr auto; gap:8px; align-items:center; padding:9px 10px; border-radius:14px; color:#edf7ff; background:linear-gradient(135deg,rgba(5,22,36,.92),rgba(3,12,20,.96)); box-shadow:inset 0 0 0 1px rgba(31,145,255,.18); font-size:11px; }
.quote-item-chip button { width:24px; height:24px; border:0; border-radius:999px; color:white; background:rgba(255,82,82,.75); font-weight:900; }
.quote-item-chip strong,.quote-item-chip span { white-space:nowrap; color:#7ec3ff; }
.quote-item-chip em { min-width:0; color:#fff; font-style:normal; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.quote-item-chip small { color:#9fb0c2; font-weight:800; white-space:nowrap; }
.external-card.has-pending { border:1px solid #ff5656;box-shadow:0 0 0 1px rgba(255,86,86,.25), var(--shadow); }
#printSheet.quote-note {
  height: auto;
  min-height: 297mm;
  overflow: visible;
  padding-bottom: 12mm;
}
#printSheet.quote-note .print-footer {
  position: static;
  margin-top: 8mm;
  border-radius: 16px;
}
.external-equipment span { padding: 6px 8px; color: #80bcff; border: 1px solid #174d91; background: #071d39; font-size: 8px; }
.currency-input { display: flex; align-items: center; border: 1px solid #244261; background: #020914; }
.currency-input > span { padding: 0 10px; color: #80bcff; font-size: 11px; font-weight: 800; }
.currency-input input { border: 0 !important; }
.barcode-field.scanner-active input { border-color: #00b764 !important; box-shadow: 0 0 0 3px rgba(0,183,100,.12); }
.barcode-field small { color: var(--muted); font-size: 8px; font-weight: 400; text-transform: none; }
.barcode-field.scanner-active small { color: #5ce0a6; }
.public-request-link, .public-login-link { display: block; margin-top: 18px; color: #67adff; text-align: center; font-size: 10px; text-decoration: none; }
.public-whatsapp-link { display:block;margin-top:18px;padding:12px;color:#fff;border:1px solid #00b764;background:#082c24;text-align:center;font-size:10px;font-weight:800;text-decoration:none; }
.public-requests-panel { margin-bottom: 15px; }
.public-request-row { display: grid; grid-template-columns: 1.5fr .8fr .7fr auto; align-items: center; gap: 14px; padding: 14px 20px; border-bottom: 1px solid var(--line); font-size: 10px; }
.public-request-row strong, .public-request-row small { display: block; }
.public-request-row small { margin-top: 4px; color: var(--muted); }
.public-page { min-height: 100vh; background: #020812; }
.public-page { overflow-x: hidden; }
.public-shell { min-height: 100vh; display: grid; grid-template-columns: .9fr 1.1fr; }
.public-hero { display: flex; flex-direction: column; justify-content: center; padding: 8vw; color: #fff; background: linear-gradient(90deg,rgba(2,8,18,.96),rgba(2,8,18,.5)),url("assets/landing/studio-real.jpg") center/cover; }
.public-hero img { width: 230px; margin-bottom: 70px; }
.public-hero h1 { margin: 12px 0; font: 600 clamp(48px,7vw,84px)/.9 Georgia,serif; }
.public-hero h1 em { color: #1682ff; }
.public-hero > p:last-child { max-width: 480px; color: #bfd0e5; line-height: 1.7; }
.public-form-area { min-width: 0; display: grid; place-items: center; padding: 35px; background: radial-gradient(circle at 50% 20%,rgba(0,104,244,.13),transparent 30%),#020711; }
.public-form-area form { width: min(650px,100%); max-width: 100%; min-width: 0; }
.security-honeypot {
  position: absolute !important;
  left: -10000px !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
}
.public-form-area h2 { margin: 8px 0 25px; font: 600 29px Georgia,serif; }
.public-success { margin-top: 15px; padding: 13px; color: #5ce0a6; border: 1px solid #00b764; background: #082c24; text-align: center; font-size: 10px; }
.public-packages { margin-top: 5px; }
.public-package-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 9px; margin-top: 11px; }
.public-package-grid label { position: relative; cursor: pointer; }
.public-package-grid input { position: absolute; opacity: 0; }
.public-package-grid span { min-height: 105px; display: flex; flex-direction: column; padding: 14px; border: 1px solid #244261; background: #020914; }
.public-package-grid input:checked + span { border: 2px solid #1682ff; background: #071d39; box-shadow: 0 0 20px rgba(0,104,244,.14); }
.public-package-grid b { font: 600 17px Georgia,serif; }
.public-package-grid small { flex: 1; margin-top: 7px; color: var(--muted); font-size: 8px; }
.public-package-grid strong { color: #67adff; font-size: 10px; }
.public-package-grid .public-package span { position: relative; min-height: 210px; align-items: center; border-radius: 5px; text-align: center; }
.public-package-grid .public-package span > i { position: absolute; top: 9px; right: 9px; display: none; width: 21px; height: 21px; place-items: center; border-radius: 50%; color: #fff; font-style: normal; font-weight: 900; }
.public-package-grid .public-package input:checked + span > i { display: grid; }
.public-package-grid .public-package span > em { margin-top: 5px; color: #fff; font-size: 8px; font-style: normal; font-weight: 800; letter-spacing: .12em; }
.public-package-grid .public-package span > b { margin: 8px 0; font: 800 25px Arial,sans-serif; }
.public-package-grid .public-package span > small { flex: 0; color: #fff; font-size: 9px; font-weight: 800; }
.public-package-grid .public-package span > strong { display: block; margin: 19px 0 12px; font: 700 18px Arial,sans-serif; }
.public-package-grid .public-package span > strong small { display: block; margin-top: 4px; color: inherit; font-size: 9px; }
.public-package-grid .public-package span > u { margin-top: auto; padding: 7px 9px; border-radius: 3px; color: #fff; font-size: 8px; font-weight: 800; text-decoration: none; }
.public-package-grid .public-package.start span { border-color: #087cff; }
.public-package-grid .public-package.start b,.public-package-grid .public-package.start strong { color: #45a1ff; }
.public-package-grid .public-package.start span > i,.public-package-grid .public-package.start span > u { background: #087cff; }
.public-package-grid .public-package.start input:checked + span { border-color: #087cff; background: linear-gradient(180deg,#071d39,#020914); box-shadow: 0 0 24px rgba(8,124,255,.2); }
.public-package-grid .public-package.pro span { border-color: #00b764; }
.public-package-grid .public-package.pro b,.public-package-grid .public-package.pro strong { color: #43dda0; }
.public-package-grid .public-package.pro span > i,.public-package-grid .public-package.pro span > u { background: #00a65a; }
.public-package-grid .public-package.pro input:checked + span { border-color: #00b764; background: linear-gradient(180deg,#082c24,#020914); box-shadow: 0 0 24px rgba(0,183,100,.18); }
.public-package-grid .public-package.premium span { border-color: #ff9700; }
.public-package-grid .public-package.premium b,.public-package-grid .public-package.premium strong { color: #ffb43d; }
.public-package-grid .public-package.premium span > i,.public-package-grid .public-package.premium span > u { background: #ff9700; }
.public-package-grid .public-package.premium input:checked + span { border-color: #ff9700; background: linear-gradient(180deg,#35230a,#020914); box-shadow: 0 0 24px rgba(255,151,0,.18); }
.public-package-total { display: grid; align-content: center; padding: 13px; border: 1px solid #1682ff; background: linear-gradient(100deg,#003e91,#006cf0); }
.public-package-total span,.public-package-total small { font-size: 8px; }
.public-package-total small { color: #cfe4ff; }
.public-package-total strong { margin: 4px 0; font: 600 19px Georgia,serif; }
.public-hours-validation { padding: 11px 13px; border: 1px solid #244261; color: var(--muted); background: #020914; font-size: 9px; }
.public-hours-validation.valid { border-color: #00b764; color: #5ce0a6; background: #082c24; }
.public-hours-validation.invalid { border-color: #ff5656; color: #ffadad; background: #351318; }
.report-tabs { display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px; }
.report-tabs button { padding:10px 15px;border:1px solid #17345b;color:#91a2b8;background:#071321;font-size:10px; }
.report-tabs button.active { border-color:#1682ff;color:#fff;background:#0068f4; }
.exit-table { display:grid;border:1px solid #20456f; }
.exit-row { display:grid;grid-template-columns:.35fr .8fr 1.3fr 1fr 1.5fr;gap:2mm;padding:2.2mm;border-bottom:1px solid #18365d;font-size:7px;align-items:center; }
.exit-row:last-child { border-bottom:0; }
.exit-head { color:#8fc4ff;background:#071d39;font-weight:800;text-transform:uppercase; }
.exit-signatures { display:grid;grid-template-columns:1fr 1fr;gap:12mm;margin-top:10mm; }
.exit-signatures div { padding-top:2mm;border-top:1px solid #7890ae;text-align:center; }
.exit-signatures span { color:#a8b9cf;font-size:7px;text-transform:uppercase; }
.print-footer.exit-footer { grid-template-columns:1fr 3fr; }
.print-footer.exit-footer .footer-brand span { display:none; }
.print-footer.quote-footer { grid-template-columns:1fr 3fr; }
.print-footer.quote-footer .footer-brand span { display:none; }
.role-operator .finance-summary,
.role-operator [data-financial] { display: none !important; }

/* Ficha A4 no padrão escuro Korban */
.print-sheet {
  color: #f7f9ff;
  background:
    radial-gradient(circle at 85% 5%, rgba(0,104,244,.2), transparent 24%),
    linear-gradient(145deg, #061327, #020812 42%, #030b17);
  -webkit-print-color-adjust: exact;
  print-color-adjust: exact;
}
.print-header { border-color: #1682ff; }
.print-logo-box { border: 1px solid #164b8e; background: #020812; }
.print-logo > span:last-child,
.print-logo > span:last-child strong { color: #fff; }
.print-logo > span:last-child small,
.print-title p { color: #91a2b8; }
.print-title h1,
.print-section h2,
.print-message { color: #48a0ff; }
.print-hero {
  border: 1px solid #1682ff;
  background: linear-gradient(90deg, #003e91, #006cf0);
}
.print-section { border-color: #18365d; background: rgba(5,16,31,.76); }
.print-section h2 { border-color: #20456f; }
.print-field span { color: #7890ae; }
.print-field strong { color: #f7f9ff; }
.print-total { border: 1px solid #1682ff; background: #0068f4; }
.payment-highlight {
  margin-top: 4mm;
  padding: 4mm;
  border: 1.5px solid #1682ff;
  background: linear-gradient(110deg, #061b39, #003e91);
  box-shadow: 0 0 0 1mm rgba(0,104,244,.08);
}
.payment-heading { display: flex; align-items: center; gap: 3mm; margin-bottom: 3mm; }
.payment-heading > span { display: grid; place-items: center; width: 9mm; height: 9mm; border-radius: 50%; color: #0068f4; background: #fff; font-size: 4mm; }
.payment-heading small { display: block; margin-bottom: .8mm; color: #8fc4ff; font-size: 6px; letter-spacing: .15em; }
.payment-heading strong { display: block; color: #fff; font-size: 10px; }
.payment-grid { display: grid; grid-template-columns: 1.4fr .6fr 1fr 1.35fr; gap: 2mm; }
.payment-grid-with-qr { grid-template-columns: 1fr .55fr .85fr 1.05fr 31mm; align-items: stretch; }
.payment-grid > div { padding: 2.5mm; border: 1px solid rgba(143,196,255,.28); background: rgba(2,8,18,.45); }
.payment-grid span { display: block; margin-bottom: 1mm; color: #8fc4ff; font-size: 5.5px; text-transform: uppercase; }
.payment-grid strong { color: #fff; font-size: 7.5px; }
.payment-grid .pix-box { border-color: #fff; background: #fff; }
.payment-grid .pix-box span { color: #005bd8; }
.payment-grid .pix-box strong { color: #020812; font-size: 8.5px; }
.pix-qr-box { display: grid; place-items: center; text-align: center; }
.pix-qr-box img { width: 24mm; height: 24mm; padding: 1mm; border-radius: 2mm; background: #fff; }
.pix-qr-box span { margin-top: 1mm; margin-bottom: .5mm; }
.pix-qr-box strong { font-size: 7px; }
.print-message p,
.print-footer { color: #a8b9cf; }
.print-footer { border-color: #21446f; }
.print-footer strong { color: #fff; }

@media (max-width: 900px) {
  .login-screen { grid-template-columns: 1fr; }
  .login-visual { min-height: 38vh; }
  .login-panel { min-height: 62vh; }
  .users-layout { grid-template-columns: 1fr; }
  .asset-layout, .external-layout { grid-template-columns: 1fr; }
  .event-equipment-workspace { grid-template-columns: 1fr; }
  .event-equipment-preview { position: static; }
  .external-note-preview { position: static; min-height: 420px; max-height: none; }
  .financial-result { grid-template-columns:1fr 1fr; }
  .public-shell { grid-template-columns: 1fr; }
  .public-hero { min-height: 45vh; padding: 45px; }
  .public-hero img { margin-bottom: 35px; }
}
@media (max-width: 650px) {
  .login-visual { padding: 28px; }
  .login-copy h1 { font-size: 42px; }
  .login-panel { padding: 18px; }
  .login-card { padding: 28px 22px; }
  .user-menu b, .user-menu small, .today { display: none; }
  .user-menu { display: block; }
  .event-equipment-tools { grid-template-columns: 1fr; }
  .note-preview-list-head { display: none; }
  #eventEquipmentPreview .preview-equipment-row { grid-template-columns: 54px 1fr; }
  #eventEquipmentPreview .preview-equipment-row img { width: 54px; height: 45px; }
  #eventEquipmentPreview .preview-equipment-row button { grid-column: 1 / -1; }
}

.migration-panel { margin-top: 22px; padding: 24px; }
.migration-actions { display: flex; flex-wrap: wrap; gap: 10px; margin: 20px 0; }
.migration-file { position: relative; overflow: hidden; cursor: pointer; }
.migration-file input { position: absolute; inset: 0; opacity: 0; cursor: pointer; }
.migration-help { display: grid; gap: 7px; padding: 16px; border: 1px solid #17345b; color: #a9bad0; background: #030b17; font-size: 10px; }
.migration-help strong { color: #fff; }
.migration-result { margin-top: 14px; padding: 16px; border: 1px solid #00b764; color: #b9f5da; background: #082c24; font-size: 10px; line-height: 1.7; }

@media print {
  body { background: #020812 !important; }
  #printSheet {
    color: #f7f9ff !important;
    background:
      radial-gradient(circle at 85% 5%, rgba(0,104,244,.2), transparent 24%),
      linear-gradient(145deg, #061327, #020812 42%, #030b17) !important;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }
}

/* Refinamento editorial da ficha A4 */
.print-sheet { position: relative; padding: 11mm 12mm 8mm; }
.print-header { min-height: 23mm; padding-bottom: 5mm; }
.print-logo { gap: 5mm; }
.print-logo > img {
  display: block;
  width: 48mm;
  height: auto;
  object-fit: contain;
}
.print-logo.logo-only > img {
  width: 50.4mm;
}
.print-logo > span { display: block; padding-left: 4mm; border-left: 1px solid #24548a; }
.print-logo > span small {
  display: block;
  margin-bottom: 1.2mm;
  color: #91a2b8;
  font-size: 6px;
  letter-spacing: .2em;
}
.print-logo > span strong {
  display: block;
  color: #fff;
  font: 700 11px/1.1 Arial, sans-serif;
  letter-spacing: .12em;
}
.print-title h1 { font-size: 18px; text-transform: uppercase; letter-spacing: .04em; }
.print-title p { font-size: 7px; }
.print-hero { margin: 4mm 0; padding: 4mm 5mm; }
.print-hero p { margin-bottom: 1.5mm; font-size: 6.5px; }
.print-hero strong { max-width: 160mm; display: block; font: 600 15px/1.2 Arial, sans-serif; letter-spacing: .01em; }
.print-grid { gap: 3mm; }
.print-section { padding: 3.5mm 4mm; }
.print-section h2 {
  margin-bottom: 2.5mm;
  padding-bottom: 2mm;
  font-size: 8px;
  font-weight: 800;
  letter-spacing: .16em;
}
.print-fields { gap: 3mm 5mm; }
.print-field span { margin-bottom: 1.2mm; font-size: 6.5px; font-weight: 700; letter-spacing: .08em; }
.print-field strong { font-size: 9.5px; line-height: 1.35; }
.print-total { margin-top: 3mm; padding: 3.5mm; }
.print-total span { font-size: 7px; font-weight: 800; letter-spacing: .08em; }
.print-total strong { font-size: 18px; }
.payment-highlight { margin-top: 3mm; padding: 3.5mm; }
.payment-heading { margin-bottom: 2.5mm; }
.payment-heading strong { font-size: 10.5px; }
.payment-grid > div { padding: 2.3mm; }
.payment-grid span { font-size: 6px; }
.payment-grid strong { font-size: 8.5px; }
.payment-grid .pix-box strong { font-size: 9.5px; }
.print-message { margin: 3.5mm 0; }
.print-message strong { font-size: 13px; }
.print-message p { margin-top: 1mm; font-size: 7.5px; }
.print-footer {
  min-height: 32mm;
  display: grid;
  grid-template-columns: 1.2fr .72fr .72fr .8fr 1.55fr;
  gap: 0;
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  margin: 0;
  padding: 5mm 12mm;
  border-top: 1px solid #1682ff;
  color: #fff;
  background: linear-gradient(100deg, #020711, #061a38);
  box-sizing: border-box;
  align-items: stretch;
}
.footer-brand,
.footer-contact { min-width: 0; height: 100%; display: flex; align-items: center; justify-content: center; gap: 2.2mm; padding: 0 3mm; border-right: 1px solid #173f6f; box-sizing: border-box; }
.footer-brand { padding-left: 0; }
.footer-brand img { width: 29mm; height: auto; }
.footer-brand span { display: none; }
.footer-contact:last-child { padding-right: 0; border-right: 0; }
.contact-icon {
  flex: 0 0 auto;
  display: grid;
  place-items: center;
  width: 7mm;
  height: 7mm;
  border: 1px solid #1682ff;
  border-radius: 50%;
  color: #48a0ff;
  font: 700 3.5mm Arial, sans-serif;
}
.play-icon { font-size: 2.7mm; }
.footer-contact small { display: block; margin-bottom: .8mm; color: #7dbbff; font-size: 5px; letter-spacing: .11em; }
.footer-contact strong { display: block; color: #fff; font-size: 7px; line-height: 1.35; }
.footer-address strong { font-size: 6.4px; }

@media print {
  #printSheet { left: 50%; right: auto; padding: 11mm 12mm 8mm; transform: translateX(-50%); }
  .print-footer { margin: 0; }
  #printSheet.exit-note { height:auto;min-height:297mm;overflow:visible; }
  #printSheet.exit-note .print-footer { position:static;margin:10mm -12mm -8mm; }
}

@media (max-width: 650px) {
  .asset-cards { grid-template-columns: 1fr; }
  .partial-payment { grid-template-columns: 1fr; }
  .financial-result { grid-template-columns:1fr; }
  .equipment-check { grid-template-columns:auto 45px 1fr; }
  .equipment-qty { grid-column:3; }
  .public-request-row { grid-template-columns: 1fr; }
  .public-package-grid { grid-template-columns: 1fr; }
  .public-form-area { padding: 18px; }
  .public-hero { padding: 32px 24px; }
}

/* PREVIA VISUAL - PREMIUM GLASS KORBAN
   Camada temporaria para validar visual moderno, sem bordas duras e sem fundos com texto. */
:root {
  --line: rgba(255,255,255,.075);
  --paper: #020711;
  --petrol-soft: rgba(0,104,244,.12);
  --shadow: 0 24px 80px rgba(0,0,0,.34);
}

body {
  background:
    radial-gradient(circle at 12% 0%, rgba(0,104,244,.20), transparent 34%),
    radial-gradient(circle at 88% 12%, rgba(0,209,255,.10), transparent 30%),
    linear-gradient(135deg, #020711, #041225 55%, #010308);
}

.main {
  background:
    linear-gradient(rgba(2,7,17,.88), rgba(2,7,17,.94)),
    url("assets/landing/studio-real.jpg") center/cover fixed;
}

.sidebar {
  border-right: 0 !important;
  background: rgba(1,6,14,.82);
  backdrop-filter: blur(22px);
  box-shadow: 18px 0 55px rgba(0,0,0,.22);
}

.topbar {
  border-bottom: 0 !important;
  background: rgba(2,9,20,.70);
  backdrop-filter: blur(24px);
  box-shadow: 0 18px 60px rgba(0,0,0,.18);
}

.view { color: #f8fbff; }
.section-intro p:not(.eyebrow), .table-row small, .panel p, .field, .today { color: #9fb2ca; }

.hero,
.login-visual,
.public-hero {
  border: 0 !important;
  background-image:
    linear-gradient(115deg, rgba(2,7,17,.96) 0%, rgba(2,7,17,.78) 45%, rgba(2,7,17,.38)),
    radial-gradient(circle at 75% 24%, rgba(0,104,244,.30), transparent 34%),
    url("assets/landing/studio-real.jpg") !important;
  background-size: cover !important;
  background-position: center 45% !important;
  border-radius: 28px;
  box-shadow: 0 32px 100px rgba(0,0,0,.42);
}

.login-visual,
.public-hero { border-radius: 0; }
.login-visual::after { border: 0; background: linear-gradient(90deg, rgba(0,104,244,.12), transparent 45%); }

.hero-art {
  background-image:
    linear-gradient(90deg, rgba(2,7,17,.94), rgba(2,7,17,.22)),
    url("assets/landing/studio-real.jpg") !important;
  background-size: cover !important;
  background-position: center 45% !important;
}

.hero-art::after {
  border-left: 0 !important;
  background:
    radial-gradient(circle at 68% 28%, rgba(0,104,244,.24), transparent 30%),
    linear-gradient(90deg, rgba(2,7,17,.64), transparent 50%);
}

.panel,
.metric,
.form-card,
.table-panel,
.package-card,
.login-card,
.public-form-area form,
.reservation-number,
.search,
.financial-result,
.payment-alerts,
.dashboard-period {
  border: 0 !important;
  border-radius: 24px;
  background: linear-gradient(145deg, rgba(7,19,33,.82), rgba(3,10,20,.72)) !important;
  box-shadow: 0 24px 70px rgba(0,0,0,.26), inset 0 1px 0 rgba(255,255,255,.045);
  backdrop-filter: blur(18px);
}

.metric,
.panel { overflow: hidden; }

.panel-head,
.booking-row,
.table-row,
.finance-line,
.public-request-row,
.calendar-head,
.calendar-legend,
.footer-brand,
.footer-contact,
.print-footer,
.field-grid,
.card-title {
  border-color: transparent !important;
}

.table-row,
.booking-row,
.public-request-row {
  margin: 8px 12px;
  border-radius: 18px;
  background: rgba(255,255,255,.035);
  transition: transform .18s ease, background .18s ease, box-shadow .18s ease;
}

.table-row:hover,
.booking-row:hover,
.public-request-row:hover {
  transform: translateY(-2px);
  background: rgba(0,104,244,.10);
  box-shadow: 0 16px 40px rgba(0,0,0,.20);
}

.field input,
.field textarea,
.field select,
select,
.currency-input {
  border: 0 !important;
  border-radius: 15px;
  background: rgba(255,255,255,.065) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.055);
}

.field select,
select,
select option,
select optgroup {
  color: #f8fbff !important;
  background-color: #071321 !important;
}

select option:hover,
select option:checked {
  color: #fff !important;
  background-color: #087cff !important;
}

.field input,
.field textarea,
.field select,
select,
input[type="date"],
input[type="month"],
input[type="time"],
input[type="datetime-local"],
.date-display-input,
.time-display-input,
.datetime-display-fields input {
  color-scheme: dark;
}

input[type="date"]::-webkit-calendar-picker-indicator,
input[type="month"]::-webkit-calendar-picker-indicator,
input[type="time"]::-webkit-calendar-picker-indicator,
input[type="datetime-local"]::-webkit-calendar-picker-indicator {
  opacity: 1;
  cursor: pointer;
  filter: invert(1) brightness(1.65) drop-shadow(0 0 4px rgba(72,160,255,.65));
}

.btn,
.nav-item,
.link-button,
.more-btn,
.icon-btn,
.public-whatsapp-link,
.public-request-link,
.public-login-link {
  border-radius: 999px !important;
}

.nav-item {
  margin-bottom: 2px;
  color: #9fb2ca;
}

.nav-item:hover,
.nav-item.active {
  background: linear-gradient(90deg, rgba(0,104,244,.95), rgba(0,178,255,.72));
  box-shadow: 0 16px 40px rgba(0,104,244,.23);
}

.package-option,
.public-package-grid span,
.equipment-check,
.asset-card,
.external-card,
.calendar-day,
.calendar-booking {
  border: 0 !important;
  border-radius: 22px;
  background: rgba(255,255,255,.055) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.045);
}

.package-option:has(input:checked),
.public-package-grid input:checked + span {
  background: linear-gradient(145deg, rgba(0,104,244,.22), rgba(0,183,255,.08)) !important;
  box-shadow: 0 18px 55px rgba(0,104,244,.23), inset 0 1px 0 rgba(255,255,255,.08);
}

.calendar-day {
  min-height: 132px;
}

.calendar-day.weekend-day {
  background:
    linear-gradient(145deg, rgba(255,151,0,.12), rgba(255,255,255,.035)) !important;
  box-shadow:
    inset 0 0 0 1px rgba(255,151,0,.18),
    inset 0 1px 0 rgba(255,255,255,.06);
}

.calendar-day.sunday-day {
  background:
    linear-gradient(145deg, rgba(255,86,86,.13), rgba(255,255,255,.035)) !important;
}

.calendar-day.weekend-day .day-number::after {
  content: "";
  margin-left: 6px;
  padding: 2px 5px;
  border-radius: 999px;
  color: #ffd28b;
  background: rgba(255,151,0,.16);
  font-size: 7px;
  font-weight: 900;
  letter-spacing: .08em;
}

.calendar-day.has-schedule {
  position: relative;
  background:
    radial-gradient(circle at 18% 8%, rgba(0,104,244,.26), transparent 34%),
    rgba(255,255,255,.075) !important;
  box-shadow:
    0 14px 34px rgba(0,104,244,.16),
    inset 0 0 0 1px rgba(22,130,255,.35),
    inset 0 1px 0 rgba(255,255,255,.08);
}

.calendar-day.has-schedule::before {
  content: "";
  position: absolute;
  inset: 8px 8px auto auto;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #1682ff;
  box-shadow: 0 0 0 5px rgba(22,130,255,.16), 0 0 22px rgba(22,130,255,.72);
}

.calendar-day.has-schedule .day-number {
  color: #fff;
  font-weight: 900;
}

.calendar-booking {
  padding: 9px 10px;
}

.date-tile,
.metric i,
.contact-icon {
  border: 0 !important;
  background: rgba(0,104,244,.16) !important;
}

.finance-ring::after { background: rgba(7,19,33,.94); }

.public-form-area {
  background:
    radial-gradient(circle at 50% 20%, rgba(0,104,244,.18), transparent 32%),
    linear-gradient(135deg, #020711, #050f1f);
}

.public-success,
.payment-alert,
.same-day-alert,
.equipment-date-warning,
.hours-error,
.admin-financial-alert {
  border: 0 !important;
  border-radius: 18px;
}
.date-display-input,
.time-display-input,
.datetime-display-fields input,
.datetime-display-fields select {
  width: 100%;
}
.datetime-display-fields {
  display: grid;
  grid-template-columns: 1fr .62fr;
  gap: 8px;
}
.event-date-row .datetime-display-fields {
  min-width: 0;
}
.date-picker-wrap {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 46px;
  gap: 8px;
  align-items: center;
}
.date-picker-wrap.is-readonly {
  grid-template-columns: 1fr;
}
.date-picker-wrap .date-display-input,
.date-picker-wrap input[name="dateDisplay"] {
  width: 100%;
}
.date-picker-button {
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  border: 1px solid #1682ff;
  border-radius: 14px;
  color: #fff;
  background: linear-gradient(145deg,#087cff,#003e91);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18), 0 12px 26px rgba(8,124,255,.20);
  cursor: pointer;
  font-size: 19px;
}
.date-picker-button:hover {
  filter: brightness(1.12);
  transform: translateY(-1px);
}
.date-picker-native {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 46px !important;
  height: 46px !important;
  opacity: 0;
  pointer-events: none;
}
.public-pix-box {
  display: grid;
  grid-template-columns: 1fr 128px;
  gap: 14px;
  align-items: center;
  padding: 15px;
  border: 1px solid rgba(22,130,255,.42);
  border-radius: 18px;
  background: linear-gradient(145deg,rgba(8,34,65,.92),rgba(2,8,18,.92));
}
.public-pix-box span,
.public-pix-box small {
  display: block;
}
.public-pix-box span {
  color: #80bcff;
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.public-pix-box strong {
  display: block;
  margin: 6px 0;
  color: #fff;
  font-size: 15px;
}
.public-pix-box small {
  color: var(--muted);
  font-size: 9px;
  line-height: 1.45;
}
.public-pix-box img {
  width: 128px;
  height: 128px;
  padding: 7px;
  border-radius: 14px;
  background: #fff;
}
.public-pix-box textarea {
  grid-column: 1 / -1;
  min-height: 58px;
  resize: vertical;
  font-size: 8px;
  line-height: 1.45;
}
.public-confirmation-modal {
  z-index: 1600;
}
.public-confirmation-window {
  width: min(980px,100%);
}
.public-confirmation-toolbar {
  border: 0;
  border-radius: 18px;
  color: #fff;
  background: rgba(3,14,29,.92);
  box-shadow: 0 22px 70px rgba(0,0,0,.38), inset 0 1px 0 rgba(255,255,255,.06);
}
.public-confirmation-toolbar small {
  color: #9fb3cb;
}
.public-confirmation-sheet {
  width: min(900px,100%);
  margin: 0 auto;
  padding: 28px;
  border-radius: 28px;
  color: #fff;
  background:
    radial-gradient(circle at 86% 0%, rgba(8,124,255,.20), transparent 28%),
    linear-gradient(145deg,#061327,#020812 46%,#030b17);
  box-shadow: 0 26px 80px rgba(0,0,0,.42), inset 0 1px 0 rgba(255,255,255,.06);
}
.public-confirmation-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  margin-bottom: 22px;
}
.public-confirmation-head img {
  width: 178px;
  max-width: 45%;
}
.public-confirmation-head div {
  text-align: right;
}
.public-confirmation-head small,
.public-confirmation-head span,
.public-confirmation-grid small,
.public-bank-card small,
.public-pix-floating span,
.public-pix-code span {
  display: block;
  color: #7dbbff;
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.public-confirmation-head strong {
  display: block;
  margin: 6px 0;
  font-size: 24px;
}
.public-confirmation-head span {
  color: #a8b9cf;
  font-size: 8px;
  letter-spacing: .08em;
}
.public-confirmation-hero {
  margin-bottom: 18px;
  padding: 18px 20px;
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.035));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.07);
}
.public-confirmation-hero span {
  display: block;
  margin-bottom: 7px;
  color: #80bcff;
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .16em;
}
.public-confirmation-hero strong {
  font-size: 17px;
  line-height: 1.35;
}
.public-confirmation-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 12px;
  margin-bottom: 18px;
}
.public-confirmation-grid article {
  min-width: 0;
  padding: 17px;
  border-radius: 18px;
  background: rgba(255,255,255,.055);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}
.public-confirmation-grid strong,
.public-confirmation-grid span {
  display: block;
}
.public-confirmation-grid strong {
  margin: 9px 0 7px;
  font-size: 15px;
}
.public-confirmation-grid span {
  color: #c4d1e2;
  font-size: 10px;
  line-height: 1.45;
}
.public-confirmation-payment {
  display: grid;
  grid-template-columns: minmax(0,1fr) 174px;
  gap: 14px;
  padding: 18px;
  border-radius: 24px;
  background:
    radial-gradient(circle at 92% 0%, rgba(255,255,255,.16), transparent 25%),
    linear-gradient(135deg,rgba(8,124,255,.82),rgba(0,62,145,.86) 48%,rgba(3,16,31,.96));
  box-shadow: 0 18px 50px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.12);
}
.public-bank-card {
  padding: 22px;
  border-radius: 19px;
  background: rgba(2,8,18,.34);
}
.public-bank-card strong {
  display: block;
  margin: 12px 0 16px;
  color: #fff;
  font-size: 17px;
}
.public-bank-card p {
  margin: 9px 0;
  font-size: 14px;
}
.public-bank-card em {
  color: #8fc4ff;
  font-style: normal;
  font-weight: 900;
}
.public-bank-card b {
  color: #fff;
}
.public-pix-floating {
  grid-row: span 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 13px;
  border-radius: 22px;
  color: #020812;
  background: radial-gradient(circle at 50% 0%,rgba(8,124,255,.18),transparent 36%),linear-gradient(180deg,#fff,#eaf4ff);
  box-shadow: 0 12px 30px rgba(0,0,0,.25);
}
.public-pix-floating span {
  color: #0068f4;
  font-size: 8px;
}
.public-pix-floating img {
  width: 132px;
  height: 132px;
  margin: 8px 0;
  padding: 8px;
  border-radius: 15px;
  background: #fff;
}
.public-pix-floating strong {
  color: #020812;
  font-size: 18px;
}
.public-pix-code {
  min-width: 0;
  padding: 15px;
  border-radius: 18px;
  background: rgba(2,8,18,.28);
}
.public-pix-code textarea {
  width: 100%;
  min-height: 72px;
  max-height: 170px;
  margin-top: 10px;
  resize: vertical;
  overflow: auto;
  color: #eaf4ff;
  border: 0;
  background: rgba(2,8,18,.72);
  font-size: 10px;
  line-height: 1.55;
}
.public-confirmation-footer {
  margin-top: 18px;
  padding: 16px;
  border-radius: 18px;
  text-align: center;
  background: rgba(255,255,255,.055);
}
.public-confirmation-footer strong,
.public-confirmation-footer span {
  display: block;
}
.public-confirmation-footer span {
  margin-top: 5px;
  color: #a8b9cf;
  font-size: 10px;
}
@media(max-width:650px){
  .public-pix-box {
    grid-template-columns: 1fr;
  }
  .public-pix-box img {
    margin: auto;
  }
  .public-confirmation-sheet {
    padding: 18px;
    border-radius: 22px;
  }
  .public-confirmation-head {
    align-items: flex-start;
  }
  .public-confirmation-grid,
  .public-confirmation-payment {
    grid-template-columns: 1fr;
  }
  .public-pix-floating {
    grid-row: auto;
  }
}

/* Ficha e nota de transporte - acabamento moderno Korban */
#printSheet {
  overflow: hidden;
}
.print-sheet {
  background:
    radial-gradient(circle at 82% 3%, rgba(0,128,255,.22), transparent 23%),
    radial-gradient(circle at 12% 78%, rgba(0,104,244,.13), transparent 30%),
    linear-gradient(145deg, #061327 0%, #020812 48%, #03101f 100%) !important;
}
.print-header {
  border: 0 !important;
}
.print-logo > span {
  border-left: 0 !important;
  padding-left: 2mm;
}
.print-title {
  padding: 3mm 4mm;
  border-radius: 16px;
  background: rgba(255,255,255,.055);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.07);
}
.print-hero {
  border: 0 !important;
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.035)) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.07), 0 10px 24px rgba(0,0,0,.12);
}
.print-section {
  border: 0 !important;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.035)) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.07), 0 10px 24px rgba(0,0,0,.12);
}
.print-section h2 {
  border: 0 !important;
  padding-bottom: 0 !important;
  color: #66b4ff !important;
}
.print-field {
  padding: 2.2mm 2.5mm;
  border-radius: 12px;
  background: rgba(2,8,18,.34);
}
.print-section.full .print-field.full {
  background: rgba(2,8,18,.28);
}
.print-field span {
  color: #7dbbff !important;
}
.print-field strong {
  color: #fff !important;
}
.print-total {
  border: 0 !important;
  border-radius: 16px;
  background: linear-gradient(135deg, #087cff, #003e91) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18), 0 12px 26px rgba(0,104,244,.18);
}
.payment-highlight {
  border: 0 !important;
  border-radius: 20px;
  background:
    radial-gradient(circle at 92% 0%, rgba(255,255,255,.20), transparent 25%),
    linear-gradient(135deg, rgba(8,124,255,.82), rgba(0,62,145,.86) 48%, rgba(3,16,31,.96)) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.13), 0 16px 34px rgba(0,0,0,.18);
}
.payment-heading > span {
  box-shadow: 0 7px 18px rgba(0,0,0,.22);
}
.payment-grid-with-qr {
  grid-template-columns: minmax(0, 1fr) 48mm !important;
  gap: 4mm !important;
  align-items: stretch;
}
.payment-grid > div {
  min-height: 16mm;
  display: flex;
  flex-direction: column;
  justify-content: center;
  border: 0 !important;
  border-radius: 14px;
  background: rgba(2,8,18,.32) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}
.payment-bank-card {
  padding: 4mm 5mm !important;
  gap: 2mm;
}
.payment-bank-card span {
  margin-bottom: 1mm !important;
  color: #8fc4ff !important;
  font-size: 7.35px !important;
  letter-spacing: .16em;
}
.payment-bank-card strong {
  font-size: 10px !important;
  line-height: 1.18;
}
.payment-bank-card strong em {
  color: #8fc4ff !important;
  font-style: normal;
  font-weight: 900;
}
.payment-bank-card strong b {
  color: #fff !important;
  font-weight: 900;
}
.pix-qr-box {
  min-height: 42mm !important;
  padding: 2.6mm !important;
  border-radius: 18px !important;
  background:
    radial-gradient(circle at 50% 0%, rgba(8,124,255,.18), transparent 36%),
    linear-gradient(180deg, rgba(255,255,255,1), rgba(231,242,255,.98)) !important;
  box-shadow: 0 10px 26px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.9) !important;
}
.pix-qr-frame {
  display: grid;
  place-items: center;
  padding: 1.5mm;
  border-radius: 15px;
  background: #fff;
  box-shadow: 0 7px 18px rgba(0,0,0,.16);
}
.pix-qr-box img {
  width: 31mm;
  height: 31mm;
  padding: 0;
  border-radius: 10px;
  background: #fff;
}
.pix-qr-box span {
  color: #0068f4 !important;
  margin-top: 1.4mm !important;
  font-size: 6.5px !important;
  letter-spacing: .16em;
}
.pix-qr-box strong {
  color: #020812 !important;
  font-size: 10.5px !important;
  line-height: 1;
}
.pix-qr-box small {
  margin-top: .6mm;
  color: #31577f;
  font-size: 5.4px;
  font-weight: 700;
}

/* Ajuste fino da ficha de reserva A4: respiro, rodapé e topo do sistema */
.topbar-page-title {
  display: none !important;
}
.topbar {
  justify-content: flex-end;
}
.topbar .mobile-menu {
  margin-right: auto;
}
#printSheet:not(.exit-note) {
  width: 210mm;
  min-height: 297mm;
  height: 297mm;
  box-sizing: border-box;
  padding: 10mm 10mm 37mm;
  display: flex;
  flex-direction: column;
}
#printSheet:not(.exit-note) .print-header {
  padding-bottom: 5mm;
  margin-bottom: 4mm;
}
#printSheet:not(.exit-note) .print-hero {
  margin: 0 0 4mm;
  padding: 3.5mm 5mm;
}
#printSheet:not(.exit-note) .print-hero strong {
  display: block;
  max-width: none;
  white-space: nowrap;
  font-size: 13.2px;
}
#printSheet:not(.exit-note) .print-grid {
  gap: 3mm;
}
#printSheet:not(.exit-note) .payment-highlight {
  margin-top: 2.6mm;
  padding: 2.8mm 3.6mm 3mm !important;
  flex-shrink: 0;
}
#printSheet:not(.exit-note) .payment-heading {
  margin-bottom: 2.4mm !important;
}
#printSheet:not(.exit-note) .payment-heading > span {
  width: 8mm;
  height: 8mm;
  font-size: 13px;
}
#printSheet:not(.exit-note) .payment-heading small {
  font-size: 5.8px;
}
#printSheet:not(.exit-note) .payment-heading strong {
  font-size: 11px;
}
#printSheet:not(.exit-note) .payment-grid-with-qr {
  grid-template-columns: minmax(0, 1fr) 39mm !important;
  gap: 3mm !important;
}
#printSheet:not(.exit-note) .payment-grid > div {
  min-height: 33mm !important;
}
#printSheet:not(.exit-note) .payment-bank-card {
  padding: 3mm 4mm !important;
  gap: 1.3mm;
}
#printSheet:not(.exit-note) .payment-bank-card span {
  font-size: 6.5px !important;
  margin-bottom: .6mm !important;
}
#printSheet:not(.exit-note) .payment-bank-card strong {
  font-size: 9px !important;
}
#printSheet:not(.exit-note) .pix-qr-box {
  min-height: 33mm !important;
  padding: 1.8mm !important;
}
#printSheet:not(.exit-note) .pix-qr-frame {
  padding: 1mm;
  border-radius: 12px;
}
#printSheet:not(.exit-note) .pix-qr-box img {
  width: 24mm;
  height: 24mm;
}
#printSheet:not(.exit-note) .pix-qr-box span {
  margin-top: .8mm !important;
  font-size: 5.5px !important;
}
#printSheet:not(.exit-note) .pix-qr-box strong {
  font-size: 9px !important;
}
#printSheet:not(.exit-note) .pix-qr-box small {
  font-size: 4.8px;
  margin-top: .2mm;
}
#printSheet:not(.exit-note) .print-message {
  margin: 2.8mm 0 0;
  flex-shrink: 0;
}
#printSheet:not(.exit-note) .print-footer {
  left: 10mm;
  right: 10mm;
  bottom: 5mm;
  min-height: 25mm;
  margin: 0;
  padding: 4mm 6mm;
  border-radius: 16px;
  flex-shrink: 0;
}
.print-message {
  border-radius: 18px;
  padding: 3.5mm 5mm;
  background: rgba(255,255,255,.055);
}
.print-footer {
  border-top: 0 !important;
  background:
    linear-gradient(100deg, rgba(2,7,17,.98), rgba(6,26,56,.98)) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}
.footer-brand,
.footer-contact {
  border-right: 0 !important;
}
.contact-icon {
  border: 0 !important;
  background: rgba(8,124,255,.18);
}
.exit-table {
  border: 0 !important;
  display: grid;
  gap: 1.3mm;
}
.exit-row {
  border-bottom: 0 !important;
  border-radius: 12px;
  background: rgba(2,8,18,.32);
}
.exit-head {
  background: rgba(8,124,255,.22) !important;
}
.exit-signatures div {
  border-top: 0 !important;
  border-radius: 14px;
  padding: 4mm 3mm 3mm;
  background: rgba(255,255,255,.055);
}

/* Ajuste front público: imagem como atmosfera, sem texto sobre texto */
.public-hero {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background-image:
    linear-gradient(115deg, rgba(2,7,17,.98) 0%, rgba(2,7,17,.90) 54%, rgba(2,7,17,.58)),
    radial-gradient(circle at 78% 20%, rgba(0,104,244,.22), transparent 36%),
    url("assets/landing/studio-real.jpg") !important;
  background-position: center 52% !important;
}
.public-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(90deg, rgba(2,7,17,.82), rgba(2,7,17,.28)),
    radial-gradient(circle at 22% 28%, rgba(8,124,255,.18), transparent 34%);
  backdrop-filter: blur(1.5px);
}
.public-hero > * {
  position: relative;
  z-index: 1;
}
.public-hero img {
  filter: drop-shadow(0 14px 34px rgba(0,0,0,.45));
}

@media print {
  body.public-page {
    background: #fff !important;
  }
  body.public-page * {
    visibility: hidden !important;
  }
  body.public-page #publicConfirmationSheet,
  body.public-page #publicConfirmationSheet * {
    visibility: visible !important;
  }
  body.public-page #publicConfirmationSheet {
    position: absolute;
    inset: 0 auto auto 0;
    width: 210mm;
    min-height: 297mm;
    margin: 0;
    padding: 13mm 12mm;
    border-radius: 0;
    box-shadow: none;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }
}

/* Orçamentos podem ter mais de uma página; não usam a trava A4 da ficha de reserva. */
#printSheet.quote-note {
  height: auto !important;
  min-height: 297mm !important;
  overflow: visible !important;
  padding-bottom: 12mm !important;
}
#printSheet.quote-note .print-footer {
  position: static !important;
  margin-top: 8mm !important;
  border-radius: 16px;
}
#printSheet.quote-note .print-grid {
  display: block !important;
}
#printSheet.quote-note .print-section {
  margin-bottom: 4mm;
  break-inside: avoid;
  page-break-inside: avoid;
}
#printSheet.quote-note .quote-items {
  break-inside: auto !important;
  page-break-inside: auto !important;
}
@media print {
  #printSheet.quote-note {
    height: auto !important;
    min-height: 297mm !important;
    overflow: visible !important;
    transform: translateX(-50%) !important;
  }
  #printSheet.quote-note .quote-items,
  #printSheet.quote-note .quote-table {
    break-inside: auto !important;
    page-break-inside: auto !important;
  }
  #printSheet.quote-note .quote-table-row,
  #printSheet.quote-note .quote-linked-assets span {
    break-inside: avoid !important;
    page-break-inside: avoid !important;
  }
}

/* Nota de saída multipágina: permite quebrar automaticamente conforme a quantidade de equipamentos. */
#printSheet.exit-note {
  height: auto !important;
  min-height: 297mm !important;
  overflow: visible !important;
  padding-bottom: 12mm !important;
}
#printSheet.exit-note .print-grid {
  display: block !important;
}
#printSheet.exit-note .print-section {
  margin-bottom: 4mm;
  break-inside: avoid;
  page-break-inside: avoid;
}
#printSheet.exit-note .exit-equipment-section {
  break-inside: auto !important;
  page-break-inside: auto !important;
}
#printSheet.exit-note .exit-table {
  display: block !important;
}
#printSheet.exit-note .exit-row {
  display: grid;
  break-inside: avoid;
  page-break-inside: avoid;
}
#printSheet.exit-note .exit-footer {
  position: static !important;
  margin: 8mm 0 0 !important;
  border-radius: 16px;
}
@media print {
  #printSheet.exit-note {
    position: static !important;
    left: auto !important;
    top: auto !important;
    width: 210mm !important;
    height: auto !important;
    min-height: 297mm !important;
    margin: 0 auto !important;
    padding: 11mm 12mm 12mm !important;
    overflow: visible !important;
    transform: none !important;
    box-sizing: border-box !important;
  }
  #printSheet.exit-note .print-header,
  #printSheet.exit-note .print-hero,
  #printSheet.exit-note .print-section:not(.exit-equipment-section),
  #printSheet.exit-note .exit-signatures,
  #printSheet.exit-note .exit-footer {
    break-inside: avoid;
    page-break-inside: avoid;
  }
  #printSheet.exit-note .exit-equipment-section,
  #printSheet.exit-note .exit-table {
    break-inside: auto !important;
    page-break-inside: auto !important;
  }
  #printSheet.exit-note .exit-row {
    break-inside: avoid !important;
    page-break-inside: avoid !important;
  }
}
