/* ===========================
   remove-lines.com — Mobile-First Design
   =========================== */

/* ─── CSS Variables ─── */
:root {
  /* Surfaces */
  --bg:      #fafaf9;
  --bg2:     #f3f2f0;
  --surface: #ffffff;
  --nav-bg:  rgba(255,255,255,.88);

  /* Borders */
  --border:        #e5e3df;
  --border-strong: #c9c5be;

  /* Text */
  --text:   #18181b;
  --text-2: #52525b;
  --muted:  #71717a;  /* raised from #a1a1aa — passes WCAG AA on --bg and --bg2 */

  /* Brand */
  --accent:     #1a6fe8;
  --brand:      #1a6fe8;
  --accent-dim: rgba(26,111,232,.08);
  --accent-mid: rgba(26,111,232,.18);

  /* Shadows */
  --shadow-sm:     0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --shadow:        0 4px 16px rgba(0,0,0,.07),0 1px 3px rgba(0,0,0,.04);
  --shadow-lg:     0 12px 40px rgba(0,0,0,.10),0 2px 8px rgba(0,0,0,.05);
  --shadow-toggle: 0 1px 4px rgba(0,0,0,.18);

  /* Radii */
  --radius-sm: 6px;
  --radius:    12px;
  --radius-lg: 18px;

  /* Theme toggle knob/track */
  --toggle-bg:     #e4e7ec;
  --toggle-border: #b0b7c3;
  --toggle-knob:   #ffffff;
  --icon-sun:      #d97706;
  --icon-moon:     #6b7280;

  /* Success state (copy button, form) */
  --success-bg:     #f0fdf4;
  --success-text:   #15803d;
  --success-border: #86efac;

  /* Fonts */
  --font-head: 'Instrument Serif',Georgia,'Times New Roman',serif;
  --font-body: 'DM Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --font-mono: 'DM Mono','Fira Mono','Courier New',monospace;

  /* Motion */
  --ease:       cubic-bezier(.25,.46,.45,.94);
  --transition: .22s var(--ease);
}

[data-theme="dark"] {
  /* Surfaces */
  --bg:      #0f0f0f;
  --bg2:     #161616;
  --surface: #1c1c1c;
  --nav-bg:  rgba(15,15,15,.85);

  /* Borders */
  --border:        #2a2a2a;
  --border-strong: #3f3f3f;

  /* Text */
  --text:   #fafafa;
  --text-2: #a8a8a8;
  --muted:  #71717a;  /* same neutral mid-grey, readable on dark surfaces */

  /* Brand */
  --accent:     #4a8ff5;
  --brand:      #4a8ff5;
  --accent-dim: rgba(74,143,245,.1);
  --accent-mid: rgba(74,143,245,.2);

  /* Shadows */
  --shadow-sm:     0 1px 3px rgba(0,0,0,.3);
  --shadow:        0 4px 20px rgba(0,0,0,.4);
  --shadow-lg:     0 12px 48px rgba(0,0,0,.5);
  --shadow-toggle: 0 1px 4px rgba(0,0,0,.4);

  /* Theme toggle knob/track */
  --toggle-bg:     #1e2a3a;
  --toggle-border: #2d3f55;
  --toggle-knob:   #2a3f5a;
  --icon-sun:      #6b7280;
  --icon-moon:     #7ab3e8;

  /* Success state — inverted for dark surfaces */
  --success-bg:     #052e16;
  --success-text:   #4ade80;
  --success-border: #166534;
}

/* ─── Reset ─── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

html{
  scroll-behavior:smooth;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}

body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
  transition:background var(--transition),color var(--transition);
  min-height:100vh;
  overflow-x:hidden;
}

/* ─── Scrollbar ─── */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--accent)}

/* ─── Navigation ─── */
/* Scoped to header nav only — footer <nav class="footer-col"> must NOT inherit these */
nav:not(.footer-col){
  position:sticky;top:0;z-index:100;
  background:var(--nav-bg);
  backdrop-filter:blur(24px) saturate(1.5);
  -webkit-backdrop-filter:blur(24px) saturate(1.5);
  border-bottom:1px solid var(--border);
  box-shadow:0 1px 0 var(--border),var(--shadow-sm);
  transition:background var(--transition),border-color var(--transition);
}

/* Explicit reset so footer nav cols inherit the footer background cleanly */
nav.footer-col{
  position:static;
  background:transparent;
  border:none;
  box-shadow:none;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
}

.nav-inner{
  max-width:1160px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 16px;height:56px;
}

.logo{
  font-family:var(--font-body);
  font-size:.9rem;font-weight:600;
  color:var(--text);text-decoration:none;
  display:flex;align-items:center;gap:10px;
  letter-spacing:-.02em;
}

.logo-icon{
  width:28px;height:28px;border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;overflow:hidden;background:none;
}

.logo-icon svg{width:28px;height:28px;display:block}

/* Mobile: hide desktop links, show hamburger */
.nav-links{display:none;list-style:none}

.nav-right{display:flex;align-items:center;gap:10px}

/* ─── Theme Toggle ─── */
.theme-toggle{
  width:72px;height:34px;
  background:var(--toggle-bg);
  border:1.5px solid var(--toggle-border);
  border-radius:34px;
  cursor:pointer;position:relative;
  transition:background var(--transition),border-color var(--transition);
  flex-shrink:0;
  display:flex;align-items:center;
  padding:0 6px;justify-content:space-between;
}

.theme-toggle::after{
  content:'';
  position:absolute;top:4px;left:4px;
  width:24px;height:24px;
  background:var(--toggle-knob);
  border-radius:50%;
  transition:transform var(--transition);
  box-shadow:var(--shadow-toggle);
  z-index:1;
}

[data-theme="dark"] .theme-toggle::after{transform:translateX(36px)}

.theme-icon{
  display:flex;align-items:center;justify-content:center;
  width:20px;height:20px;
  position:relative;z-index:0;
  pointer-events:none;flex-shrink:0;
}

.theme-icon svg{width:13px;height:13px}
.theme-icon.sun{color:var(--icon-sun)}
.theme-icon.moon{color:var(--icon-moon)}

/* ─── Hamburger ─── */
.nav-hamburger{
  display:flex;align-items:center;justify-content:center;
  background:none;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:6px 10px;
  cursor:pointer;
  color:var(--text);
  font-size:1.1rem;line-height:1;
  min-width:44px;min-height:44px;
}

/* ─── Mobile Menu ─── */
.nav-mobile-menu{
  display:none;
  position:fixed;
  top:56px;left:0;right:0;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  box-shadow:var(--shadow);
  z-index:99;
  padding:12px 0 16px;
}

.nav-mobile-menu.open{display:block}

.nav-mobile-menu ul{
  list-style:none;padding:0 16px;
  display:flex;flex-direction:column;gap:2px;
}

.nav-mobile-menu ul li a,
.nav-mobile-menu ul li a:link,
.nav-mobile-menu ul li a:visited{
  display:flex;align-items:center;
  padding:12px 8px;min-height:44px;
  font-size:.9rem;font-weight:500;
  color:var(--text-2);text-decoration:none;
  border-radius:var(--radius-sm);
  transition:background var(--transition),color var(--transition);
}

.nav-mobile-menu ul li a:hover,
.nav-mobile-menu ul li a:focus-visible{background:var(--bg2);color:var(--text)}

/* ─── Hero ─── */
.hero{
  max-width:1160px;margin:0 auto;
  padding:40px 16px;
  display:flex;flex-direction:column;align-items:center;
  gap:28px;text-align:center;
}

.hero-badge{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--accent-dim);color:var(--accent);
  border:1px solid var(--accent-mid);
  padding:4px 12px;border-radius:100px;
  font-size:.72rem;font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;margin-bottom:16px;
}

.hero-badge::before{content:'';width:5px;height:5px;background:var(--accent);border-radius:50%}

h1{
  font-family:var(--font-head);
  font-size:clamp(2rem,9vw,2.6rem);
  font-weight:400;line-height:1.1;
  letter-spacing:-.01em;margin-bottom:20px;color:var(--text);
}

h1 em{font-style:italic;color:var(--accent)}

.hero-desc{
  font-size:.9rem;color:var(--text-2);
  max-width:480px;margin-left:auto;margin-right:auto;
  line-height:1.7;font-weight:400;
}

/* ─── Tool Area ─── */
.tool-wrap{width:100%;max-width:1100px;margin:0 auto;padding:0 16px 72px}

.tool-grid{display:grid;grid-template-columns:1fr;gap:20px;align-items:start}

.tool-panel{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);
}

.panel-header{
  padding:16px 20px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  background:var(--bg2);
}

.panel-title{font-size:.8rem;font-weight:600;color:var(--text);letter-spacing:.03em;text-transform:uppercase}
.panel-meta{font-size:.75rem;color:var(--text-2);font-weight:500}
.panel-body{padding:0}

textarea.main-input,
textarea.main-output{
  width:100%;height:240px;
  background:var(--surface);
  border:none;outline:none;resize:none;
  padding:18px 20px;
  font-family:var(--font-mono);
  font-size:.825rem;line-height:1.7;color:var(--text);
  transition:background var(--transition),color var(--transition);
}

textarea.main-input::placeholder{color:var(--muted)}
textarea.main-output{background:var(--bg);color:var(--text-2)}

/* ─── Options Bar ─── */
.options-bar{max-width:1100px;margin:0 auto;padding:0 16px 16px}

.options-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:20px 24px;box-shadow:var(--shadow-sm);
}

.options-title{
  font-size:.75rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.06em;
  color:var(--text-2);margin-bottom:14px;
}

.options-grid{display:flex;flex-wrap:wrap;gap:7px}

.opt-toggle{
  display:flex;align-items:center;gap:8px;
  background:var(--bg2);border:1px solid var(--border);
  border-radius:100px;padding:7px 14px;min-height:36px;
  cursor:pointer;font-size:.8rem;font-weight:500;color:var(--text-2);
  transition:border-color var(--transition),color var(--transition),background var(--transition);
  user-select:none;
}

.opt-toggle:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}
.opt-toggle.active{background:var(--accent);border-color:var(--accent);color:var(--surface)}
.opt-toggle .icon{font-size:.9rem}

/* ─── Action Bar ─── */
.action-bar{
  max-width:1100px;margin:0 auto;
  padding:0 16px 20px;
  display:flex;flex-direction:column;align-items:stretch;gap:12px;
}

/* Shared button base */
.btn-primary,.btn-secondary,.btn-copy{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border-radius:var(--radius-sm);padding:11px 20px;min-height:44px;width:100%;
  font-family:var(--font-body);font-weight:500;font-size:.875rem;
  cursor:pointer;letter-spacing:-.01em;
}

.btn-primary{
  background:var(--accent);color:var(--surface);
  border:none;font-weight:600;
  transition:opacity var(--transition),transform var(--transition);
}

.btn-primary:hover{opacity:.88;transform:translateY(-1px)}

.btn-secondary{
  background:var(--bg2);border:1px solid var(--border);color:var(--text-2);
  transition:border-color var(--transition),color var(--transition),background var(--transition);
}

.btn-secondary:hover{border-color:var(--border-strong);color:var(--text);background:var(--bg)}

.btn-copy{
  background:var(--bg2);border:1px solid var(--border);color:var(--text-2);margin-left:0;
  transition:border-color var(--transition),color var(--transition),background var(--transition);
}

.btn-copy:hover{border-color:var(--accent);color:var(--accent)}

.btn-copy.copied{
  background:var(--success-bg);
  border-color:var(--success-border);
  color:var(--success-text);
}

/* ─── Stats Bar ─── */
.stats-bar{
  max-width:1100px;margin:0 auto;
  padding:0 16px 48px;
  display:flex;gap:12px;flex-wrap:wrap;
}

.stat-chip{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:7px 14px;
  font-size:.775rem;color:var(--text-2);font-weight:500;
  display:flex;align-items:center;gap:6px;
}

.stat-chip strong{color:var(--accent)}

/* ─── Sections ─── */
.section{padding:48px 16px;border-top:1px solid var(--border)}
.section-inner{max-width:1100px;margin:0 auto}

.section-label{
  font-size:.72rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.08em;
  color:var(--accent);margin-bottom:10px;
}

.section-title{
  font-family:var(--font-head);
  font-size:clamp(1.9rem,3.5vw,2.9rem);
  font-weight:400;line-height:1.15;
  letter-spacing:-.01em;margin-bottom:14px;color:var(--text);
}

.section-desc{font-size:.95rem;color:var(--text-2);max-width:520px;line-height:1.7}

/* ─── Features ─── */
.features-grid{display:grid;grid-template-columns:1fr;gap:20px;margin-top:28px}

.feat-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:28px 24px;
  transition:box-shadow var(--transition),transform var(--transition),border-color var(--transition);
}

.feat-card:hover{box-shadow:var(--shadow);transform:translateY(-2px);border-color:var(--border-strong)}

.feat-icon{
  width:44px;height:44px;
  background:var(--accent-dim);border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;margin-bottom:16px;
  border:1px solid var(--accent-mid);
}

.feat-title{font-weight:600;font-size:.95rem;margin-bottom:8px;letter-spacing:-.01em;color:var(--text)}
.feat-desc{font-size:.825rem;color:var(--text-2);line-height:1.65}

/* ─── Steps ─── */
.steps{
  display:grid;grid-template-columns:1fr;
  gap:0;margin-top:28px;
  border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;
}

.step{padding:32px 28px;border-bottom:1px solid var(--border);background:var(--surface)}
.step:last-child{border-bottom:none}

.step-num{
  font-family:var(--font-head);
  font-size:2.2rem;color:var(--accent);
  font-weight:400;line-height:1;margin-bottom:14px;opacity:.6;
}

.step-title{font-weight:600;font-size:.95rem;margin-bottom:8px;color:var(--text)}
.step-desc{font-size:.825rem;color:var(--text-2);line-height:1.65}

/* ─── FAQ ─── */
.faq-list{margin-top:40px;display:flex;flex-direction:column;gap:2px}

.faq-item{
  border:1px solid var(--border);border-radius:var(--radius-sm);
  overflow:hidden;background:var(--surface);
  transition:border-color var(--transition);
}

.faq-item.open{border-color:var(--accent)}

.faq-q{
  padding:18px 22px;min-height:56px;
  font-weight:600;font-size:.9rem;color:var(--text);
  cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;
  gap:12px;user-select:none;
}

.faq-q:hover,.faq-q:focus-visible{background:var(--bg2);outline:none}

.faq-chevron{
  flex-shrink:0;transition:transform var(--transition);
  color:var(--text-2);font-size:.75rem;
}

.faq-item.open .faq-chevron{transform:rotate(180deg);color:var(--accent)}

.faq-a{padding:0 22px 18px;font-size:.875rem;color:var(--text-2);line-height:1.75}

/* ─── CTA Banner ─── */
.cta-banner{
  background:var(--accent);
  padding:48px 16px;text-align:center;
  /* white is safe on any accent colour */
  color:#fff;
}

.cta-banner h2{
  font-family:var(--font-head);
  font-size:clamp(2rem,4vw,3rem);
  font-weight:400;margin-bottom:14px;line-height:1.15;color:#fff;
}

.cta-banner p{color:rgba(255,255,255,.88);font-size:.95rem;margin-bottom:28px}

.cta-btn-white{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:#fff;color:var(--accent);
  border:none;border-radius:var(--radius-sm);
  padding:13px 28px;min-height:48px;width:100%;
  font-family:var(--font-body);font-weight:600;font-size:.9rem;
  cursor:pointer;text-decoration:none;
  transition:opacity var(--transition),transform var(--transition);
}

.cta-btn-white:hover{opacity:.9;transform:translateY(-1px)}

/* ─── Footer ─── */
footer{
  background:var(--bg2);border-top:1px solid var(--border);
  padding:40px 16px 80px;
  /* Set base color so all children inherit correct value */
  color:var(--text-2);
}

.footer-inner{
  max-width:1160px;margin:0 auto;
  display:grid;grid-template-columns:1fr;
  gap:32px;margin-bottom:40px;
}

.footer-brand .logo{margin-bottom:14px}
.footer-brand p{font-size:.825rem;color:var(--text-2);line-height:1.7;max-width:280px}

/* Global footer link reset — beats browser UA blue for all <a> inside footer */
footer a,
footer a:link,
footer a:visited{color:var(--text-2);text-decoration:none}

footer a:hover,
footer a:focus-visible{color:var(--text)}

/* Column headings */
.footer-col{color:var(--text-2)}

.footer-col h4{
  font-weight:600;font-size:.8rem;
  text-transform:uppercase;letter-spacing:.06em;
  color:var(--text-2);margin-bottom:14px;
}

.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}

/* Explicit per-link rules reinforce the footer global reset */
.footer-col a,
.footer-col a:link,
.footer-col a:visited{
  font-size:.825rem;color:var(--text-2);text-decoration:none;
  transition:color var(--transition);
}

.footer-col a:hover,
.footer-col a:focus-visible{color:var(--text)}

/* Bottom bar */
.footer-bottom{
  max-width:1160px;margin:0 auto;
  padding-top:24px;border-top:1px solid var(--border);
  display:flex;justify-content:center;align-items:center;
  font-size:.775rem;color:var(--text-2);
  flex-wrap:wrap;gap:6px;
  flex-direction:column;text-align:center;
}

.footer-bottom-link,
.footer-bottom-link:link,
.footer-bottom-link:visited{color:var(--text-2);text-decoration:none;transition:color var(--transition)}

.footer-bottom-link:hover,
.footer-bottom-link:focus-visible{color:var(--text)}

/* ─── Inner Pages ─── */
.page-hero{border-bottom:1px solid var(--border);padding:40px 16px;text-align:center}
.page-hero h1{font-size:clamp(2.2rem,4.5vw,3.4rem);margin-bottom:14px;color:var(--text)}
.page-hero p{color:var(--text-2);font-size:1rem}

.page-content{max-width:720px;margin:72px auto;padding:0 28px}

.page-content h2{
  font-family:var(--font-head);
  font-size:1.5rem;font-weight:400;
  margin:44px 0 14px;color:var(--text);letter-spacing:-.01em;
}

.page-content h2:first-child{margin-top:0}
.page-content p{color:var(--text-2);font-size:.9rem;line-height:1.8;margin-bottom:16px}
.page-content ul{color:var(--text-2);font-size:.9rem;line-height:1.8;margin-bottom:16px;padding-left:18px}
.page-content ul li{margin-bottom:8px}

/* ─── Contact ─── */
.contact-grid{display:grid;grid-template-columns:1fr;gap:56px;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:20px}
.contact-item{display:flex;gap:14px;align-items:flex-start}

.contact-icon{
  width:40px;height:40px;flex-shrink:0;
  background:var(--bg2);border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;border:1px solid var(--border);
}

.contact-item h4{font-weight:600;margin-bottom:3px;font-size:.9rem;color:var(--text)}
.contact-item p{font-size:.825rem;color:var(--text-2)}

.contact-form{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:24px 18px;box-shadow:var(--shadow-sm);
}

.form-group{margin-bottom:18px}

.form-group label{
  display:block;font-size:.8rem;font-weight:600;
  margin-bottom:7px;color:var(--text);letter-spacing:-.005em;
}

.form-group input,
.form-group select,
.form-group textarea{
  width:100%;background:var(--bg);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:10px 14px;font-family:var(--font-body);
  font-size:16px;/* 16px prevents iOS auto-zoom */
  color:var(--text);
  transition:border-color var(--transition),box-shadow var(--transition);
  outline:none;
}

.form-group input::placeholder,
.form-group textarea::placeholder{color:var(--muted)}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}

.form-group textarea{resize:vertical;min-height:110px}

.form-submit{
  width:100%;padding:12px;min-height:44px;
  background:var(--accent);color:var(--surface);
  border:none;border-radius:var(--radius-sm);
  font-family:var(--font-body);font-weight:500;font-size:.925rem;
  cursor:pointer;letter-spacing:-.01em;
  transition:opacity var(--transition),transform var(--transition);
}

.form-submit:hover{opacity:.85;transform:translateY(-1px)}

.success-msg{
  background:var(--success-bg);
  color:var(--success-text);
  border:1px solid var(--success-border);
  border-radius:var(--radius-sm);padding:11px 14px;
  font-size:.825rem;margin-top:12px;display:none;
}

/* ─── Utilities ─── */
.divider{height:1px;background:var(--border);max-width:1160px;margin:0 auto}

/* ─── Animations ─── */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(22px)}
  to{opacity:1;transform:translateY(0)}
}

@media (prefers-reduced-motion:no-preference){
  .fade-up{animation:fadeUp .55s var(--ease) both}
  .fade-up-1{animation-delay:.06s}
  .fade-up-2{animation-delay:.14s}
  .fade-up-3{animation-delay:.22s}
  .fade-up-4{animation-delay:.30s}
}

/* ===========================
   TABLET: min-width 640px
   =========================== */
@media (min-width:640px){
  .nav-inner{padding:0 28px;height:64px}
  .nav-mobile-menu{top:64px}
  .logo{font-size:1rem}
  .logo-icon{width:34px;height:34px}
  .logo-icon svg{width:34px;height:34px}

  .hero{padding:72px 28px 56px;gap:40px}
  h1{font-size:clamp(2.4rem,4.5vw,3.8rem)}
  .hero-desc{font-size:1rem}

  .tool-wrap,.options-bar,.action-bar,.stats-bar{padding-left:28px;padding-right:28px}
  textarea.main-input,textarea.main-output{height:340px}
  .options-grid{gap:10px}

  .action-bar{flex-direction:row;align-items:center}
  .btn-primary,.btn-secondary,.btn-copy{width:auto;justify-content:flex-start}
  .btn-copy{margin-left:auto}

  .section{padding:72px 28px}
  .features-grid{grid-template-columns:1fr 1fr;margin-top:48px}
  .steps{grid-template-columns:repeat(3,1fr);margin-top:48px}
  .step{border-right:1px solid var(--border);border-bottom:none}
  .step:last-child{border-right:none}

  .cta-banner{padding:72px 28px}
  .cta-btn-white{width:auto}

  footer{padding:56px 28px 32px}
  .footer-bottom{flex-direction:row;justify-content:space-between;text-align:left}

  .page-hero{padding:72px 28px}
  .contact-form{padding:36px}
  body{padding-bottom:0}
}

/* ===========================
   DESKTOP: min-width 900px
   =========================== */
@media (min-width:900px){
  .nav-links{display:flex;align-items:center;gap:24px}
  .nav-hamburger{display:none}
  .nav-mobile-menu{display:none!important}

  .nav-links a,
  .nav-links a:link,
  .nav-links a:visited{
    font-size:.825rem;font-weight:500;
    color:var(--text-2);text-decoration:none;
    transition:color var(--transition);letter-spacing:-.005em;
  }

  .nav-links a:hover,
  .nav-links a:focus-visible{color:var(--text)}

  .tool-grid{grid-template-columns:1fr 1fr}
  .features-grid{grid-template-columns:repeat(3,1fr)}
  .footer-inner{grid-template-columns:2fr 1fr 1fr 1fr;gap:40px}
  .contact-grid{grid-template-columns:1fr 1fr}
}
