:root {
  --navy: #06264a;
  --navy-2: #083b5c;
  --teal: #008c8c;
  --teal-2: #14b8a6;
  --mint: #effdfa;
  --line: #dbe8ec;
  --text: #15324a;
  --muted: #5f7385;
  --white: #ffffff;
  --shadow: 0 22px 70px rgba(2, 37, 62, .13);
  --radius: 28px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  color: var(--text);
  background: #eef8fb;
  line-height: 1.6;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button, input, select, textarea { font: inherit; }
.wrap { width: min(1180px, calc(100% - 32px)); margin: 0 auto; }
.skip-link { position:absolute; left:-999px; top:10px; background:#fff; padding:10px; z-index:99; }
.skip-link:focus { left:10px; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(219,232,236,.85);
}
.nav-wrap {
  height: 84px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
}
.brand img { width: 218px; height: auto; }
.main-nav { display: flex; gap: 26px; align-items: center; font-weight: 700; font-size: 14px; color: var(--navy); }
.main-nav a { position: relative; padding: 30px 0; }
.main-nav a::after { content:""; position:absolute; left:0; right:0; bottom:22px; height:3px; border-radius:2px; background:var(--teal); transform:scaleX(0); transform-origin:left; transition:.2s ease; }
.main-nav a:hover::after { transform:scaleX(1); }
.menu-btn { display:none; width:44px; height:44px; border:1px solid var(--line); border-radius:12px; background:#fff; align-items:center; justify-content:center; flex-direction:column; gap:5px; cursor:pointer; }
.menu-btn span { width:21px; height:2px; background:var(--navy); border-radius:4px; }

.hero-section { position: relative; padding: 34px 0 0; overflow: hidden; }
.rize-bg { position:absolute; inset:0; background-image: linear-gradient(90deg, rgba(6,38,74,.20), rgba(0,140,140,.10)), url('https://images.unsplash.com/photo-1609311512950-6818754ea7dd?auto=format&fit=crop&w=2200&q=82'); background-size: cover; background-position:center; opacity:.95; }
.hero-section::after { content:""; position:absolute; inset:0; background: linear-gradient(90deg, rgba(255,255,255,.58), rgba(255,255,255,.18)); pointer-events:none; }
.hero-card {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: .78fr 1.22fr;
  align-items: stretch;
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(255,255,255,.7);
  border-radius: 32px;
  box-shadow: var(--shadow);
  overflow: hidden;
  min-height: 520px;
}
.hero-copy { padding: 58px 42px; display:flex; flex-direction:column; justify-content:center; }
.eyebrow { display:inline-flex; width:max-content; max-width:100%; color: var(--teal); font-weight: 850; font-size: 13px; letter-spacing: .04em; text-transform: uppercase; margin-bottom: 12px; }
h1 { color: var(--navy); font-size: clamp(40px, 5vw, 66px); line-height: .99; letter-spacing: -.045em; margin-bottom: 20px; }
h1 strong { color: var(--teal); }
.hero-copy p { font-size: 18px; color: var(--text); max-width: 560px; margin-bottom: 26px; }
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; }
.btn { display:inline-flex; align-items:center; justify-content:center; gap:9px; min-height:48px; padding: 13px 22px; border-radius: 13px; border:1px solid transparent; font-weight: 850; cursor:pointer; transition:.18s ease; }
.btn:hover { transform: translateY(-1px); }
.btn-primary { background: linear-gradient(135deg, var(--teal), #0f766e); color:#fff; box-shadow: 0 14px 30px rgba(0,140,140,.24); }
.btn-outline { color: var(--teal); background:#fff; border-color: rgba(0,140,140,.45); }
.btn-light { background:#fff; color:var(--teal); }
.btn-full { width:100%; border:0; }
.hero-image { display:flex; align-items:stretch; background:#f7fafa; position:relative; }
.hero-image img { width:100%; height:100%; object-fit:cover; object-position:center; }

.trust-strip { position: relative; z-index: 3; margin-top: -34px; }
.trust-grid { background:#fff; border:1px solid var(--line); border-radius:20px; box-shadow: 0 16px 42px rgba(2,37,62,.1); display:grid; grid-template-columns: repeat(4, 1fr); overflow:hidden; }
.trust-item { display:flex; align-items:center; justify-content:center; gap:12px; padding:20px 12px; color:var(--navy); border-right:1px solid var(--line); }
.trust-item:last-child { border-right:0; }
.trust-item span { width:36px; height:36px; display:grid; place-items:center; border-radius:50%; background:var(--mint); color:var(--teal); font-weight:900; }

.section { padding: 86px 0; background:#fff; }
.section.soft { background: #f2fbfa; }
.section-head { text-align:center; max-width:780px; margin: 0 auto 34px; }
.section-head.left { text-align:left; margin-left:0; }
h2 { color: var(--navy); font-size: clamp(30px, 3.6vw, 46px); line-height:1.08; letter-spacing:-.025em; margin-bottom: 14px; }
.section-head p { color:var(--muted); font-size:17px; }
.service-grid { display:grid; grid-template-columns: repeat(5, 1fr); gap:18px; }
.service-card { background:#fff; border:1px solid var(--line); border-radius:22px; overflow:hidden; box-shadow:0 14px 34px rgba(2,37,62,.07); transition:.2s ease; }
.service-card:hover { transform: translateY(-4px); box-shadow:0 24px 50px rgba(2,37,62,.12); }
.service-card img { width:100%; aspect-ratio: 1.45 / 1; object-fit:cover; object-position:center; border-bottom:1px solid var(--line); background:#eef8fb; }
.service-card div { padding:20px; }
.service-card h3 { color:var(--navy); font-size:18px; margin-bottom:8px; line-height:1.2; }
.service-card p { color:var(--muted); font-size:14px; }

.steps-grid { display:grid; grid-template-columns: repeat(4, 1fr); gap:20px; }
.step-card { position:relative; background:#fff; border:1px solid var(--line); border-radius:22px; padding:26px; box-shadow:0 12px 26px rgba(2,37,62,.05); }
.step-card span { display:grid; place-items:center; width:46px; height:46px; border-radius:50%; background:var(--mint); color:var(--teal); font-weight:900; font-size:20px; margin-bottom:18px; }
.step-card h3 { color:var(--navy); margin-bottom:8px; }
.step-card p { color:var(--muted); }

.corporate-grid { display:grid; grid-template-columns: 1fr .9fr; gap:30px; align-items:stretch; }
.corporate-copy { background:linear-gradient(135deg, var(--navy), #06465d); color:#fff; border-radius:var(--radius); padding:44px; overflow:hidden; position:relative; }
.corporate-copy .eyebrow { color:#70f0e1; }
.corporate-copy h2 { color:#fff; }
.corporate-copy p { color:rgba(255,255,255,.85); margin-bottom:18px; font-size:17px; }
.clean-list { list-style:none; display:grid; gap:10px; margin: 18px 0 28px; }
.clean-list li { position:relative; padding-left:28px; color:rgba(255,255,255,.9); }
.clean-list li::before { content:"✓"; position:absolute; left:0; top:0; color:#70f0e1; font-weight:900; }
.corporate-visual { border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); min-height:360px; }
.corporate-visual img { width:100%; height:100%; object-fit:cover; }

.quote-section { background: linear-gradient(180deg, #fff, #eefbfa); }
.quote-wrap { display:grid; grid-template-columns: .8fr 1.2fr; gap:28px; align-items:start; }
.quote-info { background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:36px; box-shadow:0 16px 42px rgba(2,37,62,.07); }
.quote-info p { color:var(--muted); font-size:17px; margin-bottom:18px; }
.notice-box { background:#ecfdf5; border:1px solid #b7eddc; color:#0f5c4e; padding:16px; border-radius:18px; }
.quote-form { background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:28px; box-shadow:var(--shadow); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-row.single { grid-template-columns:1fr; }
.quote-form label { display:block; color:var(--navy); font-weight:800; font-size:14px; margin-bottom:16px; }
.quote-form input, .quote-form select, .quote-form textarea { width:100%; margin-top:7px; border:1px solid #cddde3; border-radius:12px; min-height:48px; padding:13px 14px; color:var(--text); background:#fbfefe; outline:none; transition:.18s ease; }
.quote-form textarea { resize:vertical; }
.quote-form input:focus, .quote-form select:focus, .quote-form textarea:focus { border-color:var(--teal); box-shadow:0 0 0 4px rgba(20,184,166,.12); background:#fff; }
.priority-field { border:1px solid #cddde3; border-radius:16px; padding:14px; margin: 0 0 16px; background:#fbfefe; }
.priority-field legend { padding:0 8px; color:var(--navy); font-weight:900; font-size:14px; }
.priority-options { display:grid; grid-template-columns:repeat(3, 1fr); gap:12px; margin-top:8px; }
.priority-card { display:flex!important; align-items:flex-start; gap:10px; min-height:96px; margin:0!important; padding:13px!important; border:1px solid var(--line); border-radius:14px; background:#fff; cursor:pointer; transition:.18s ease; }
.priority-card input { width:18px!important; height:18px!important; min-height:auto!important; flex:0 0 18px; margin:3px 0 0!important; accent-color:var(--teal); }
.priority-card span { display:grid; gap:3px; line-height:1.25; }
.priority-card strong { font-size:15px; color:var(--navy); }
.priority-card small { color:var(--muted); font-weight:650; }
.priority-card:hover { transform:translateY(-1px); box-shadow:0 12px 24px rgba(2,37,62,.08); }
.priority-urgent { border-color:#fecaca; background:#fff7f7; }
.priority-urgent strong { color:#b91c1c; }
.priority-urgent input { accent-color:#dc2626; }
.priority-urgent:has(input:checked) { border-color:#dc2626; box-shadow:0 0 0 4px rgba(220,38,38,.12); }
.priority-normal:has(input:checked) { border-color:#94a3b8; box-shadow:0 0 0 4px rgba(15,23,42,.08); }
.priority-later { border-color:#bfdbfe; background:#f8fbff; }
.priority-later strong { color:#1d4ed8; }
.priority-later input { accent-color:#2563eb; }
.priority-later:has(input:checked) { border-color:#2563eb; box-shadow:0 0 0 4px rgba(37,99,235,.12); }
.priority-field.input-error { border-color:#ef4444!important; background:#fff7f7!important; }
.check-line { display:flex!important; align-items:flex-start; gap:12px; font-weight:600!important; color:var(--muted)!important; }
.check-line input { width:18px!important; min-height:auto!important; height:18px; flex:0 0 18px; margin-top:2px!important; }
.form-small { margin-top:12px; color:var(--muted); font-size:13px; text-align:center; }
.form-message { padding:14px 16px; border-radius:14px; font-weight:800; margin-bottom:16px; }
.form-message.ok { background:#ecfdf5; color:#065f46; border:1px solid #a7f3d0; }
.form-message.error { background:#fef2f2; color:#991b1b; border:1px solid #fecaca; }
.hp-field { position:absolute; left:-9999px; width:1px!important; height:1px!important; opacity:0; pointer-events:none; }
.input-error { border-color:#ef4444!important; background:#fff7f7!important; }

.faq-wrap { max-width:920px; }
.faq-list { display:grid; gap:14px; }
details { background:#fff; border:1px solid var(--line); border-radius:18px; overflow:hidden; box-shadow:0 10px 22px rgba(2,37,62,.04); }
summary { cursor:pointer; padding:20px 22px; font-weight:900; color:var(--navy); list-style:none; }
summary::-webkit-details-marker { display:none; }
details p { padding:0 22px 20px; color:var(--muted); }

.legal-section { padding-top:70px; }
.legal-grid { display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.legal-grid article { background:#f8fcfc; border:1px solid var(--line); border-radius:22px; padding:28px; }
.legal-grid h2 { font-size:25px; }
.legal-grid p { color:var(--muted); }

.site-footer { background:var(--navy); color:#fff; padding:60px 0 22px; }
.footer-grid { display:grid; grid-template-columns:1.25fr .9fr 1fr 1fr; gap:36px; }
.footer-logo { width:210px; background:#fff; border-radius:14px; margin-bottom:16px; }
.site-footer p, .site-footer a { color:rgba(255,255,255,.78); display:block; margin:7px 0; overflow-wrap:anywhere; }
.site-footer a:hover { color:#fff; }
.site-footer h3 { margin-bottom:14px; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.16); display:flex; justify-content:space-between; gap:20px; padding-top:20px; margin-top:34px; color:rgba(255,255,255,.65); }

@media (max-width: 1020px) {
  .menu-btn { display:flex; }
  .main-nav { position:absolute; top:84px; left:16px; right:16px; display:none; flex-direction:column; gap:0; align-items:stretch; background:#fff; border:1px solid var(--line); border-radius:20px; box-shadow:var(--shadow); padding:10px; }
  .main-nav.open { display:flex; }
  .main-nav a { padding:15px 14px; border-radius:12px; }
  .main-nav a:hover { background:var(--mint); }
  .main-nav a::after { display:none; }
  .hero-card { grid-template-columns:1fr; }
  .hero-copy { padding:40px 28px 20px; }
  .hero-image { min-height:330px; max-height:460px; }
  .trust-grid { grid-template-columns:1fr 1fr; }
  .service-grid { grid-template-columns:repeat(2, 1fr); }
  .steps-grid, .corporate-grid, .quote-wrap, .legal-grid, .footer-grid { grid-template-columns:1fr; }
}
@media (max-width: 640px) {
  .wrap { width:min(100% - 22px, 1180px); }
  .nav-wrap { height:76px; }
  .brand img { width:178px; }
  .main-nav { top:76px; }
  .hero-section { padding-top:16px; }
  .hero-card { border-radius:24px; min-height:auto; }
  .hero-copy { padding:30px 18px 18px; }
  h1 { font-size:38px; }
  .hero-copy p { font-size:16px; }
  .btn { width:100%; }
  .trust-strip { margin-top:14px; }
  .trust-grid { grid-template-columns:1fr 1fr; border-radius:18px; }
  .trust-item { padding:16px 8px; flex-direction:column; text-align:center; font-size:13px; }
  .section { padding:58px 0; }
  .service-grid { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; gap:0; }
  .priority-options { grid-template-columns:1fr; }
  .priority-card { min-height:auto; }
  .quote-form, .quote-info, .corporate-copy { padding:22px; border-radius:22px; }
  .footer-bottom { flex-direction:column; }
}
