/* ============================================================
   KOD — Hayat & İlişkiler
   Tasarım: Editoryal  /  UI/UX cilalı
   ============================================================ */

/* === FONTS === */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,400;9..40,500;9..40,600&family=Newsreader:opsz,wght@16..72,400;16..72,500;16..72,600;16..72,700&display=swap');

/* === TOKENS === */
:root {
  --ink:        #F0ECE6;
  --ink-light:  #1E2030;
  --paper:      #0C0D14;
  --paper-dim:  #14151F;
  --fog:        #5A5670;
  --stone:      #7E7A90;
  --blue:       #6B8CFF;
  --blue-deep:  #4466CC;
  --blue-pale:  #1A2040;
  --blue-glow:  rgba(107,140,255,0.06);
  --blue-ring:  rgba(107,140,255,0.2);

  --font-text:    'DM Sans', -apple-system, sans-serif;
  --font-display: 'Newsreader', Georgia, serif;

  --fs-hero:    clamp(3.5rem, 7vw, 5.5rem);
  --fs-h1:      clamp(2.5rem, 5vw, 3.75rem);
  --fs-h2:      clamp(2rem, 3.5vw, 2.5rem);
  --fs-h3:      1.625rem;
  --fs-h4:      1.125rem;
  --fs-body:    1.0625rem;
  --fs-small:   0.875rem;
  --fs-caption: 0.75rem;
  --fs-label:   0.6875rem;

  --lh-tight:   1.1;
  --lh-body:    1.65;
  --lh-relaxed: 1.8;

  --s-macro:    clamp(4rem, 8vw, 7rem);
  --s-section:  clamp(3rem, 6vw, 5rem);
  --s-gutter:   2rem;
  --s-card:     2.5rem;
  --s-inner:    1.5rem;

  --w-max:       1280px;
  --w-narrow:    720px;
  --w-medium:    960px;

  --hairline:      1px solid rgba(255,255,255,0.07);
  --hairline-dark: 1px solid rgba(255,255,255,0.06);
  --radius:        2px;
  --ease:          cubic-bezier(0.22, 0.61, 0.36, 1);
  --ease-out:      cubic-bezier(0, 0, 0.2, 1);
}

/* === RESET === */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth;scroll-padding-top:80px}
body{
  font-family:var(--font-text);font-size:var(--fs-body);
  line-height:var(--lh-body);color:var(--ink);background:var(--paper);
  -webkit-font-smoothing:antialiased;overflow-x:hidden
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer;border:none;font:inherit;background:none}
input,textarea,select{font:inherit;color:inherit}

body::after{
  content:'';position:fixed;inset:0;z-index:9999;
  pointer-events:none;opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")
}
::selection{background:var(--blue);color:var(--paper)}

/* === FOCUS RING === */
:focus-visible{
  outline:2px solid var(--blue-ring);
  outline-offset:2px;
  border-radius:1px
}

/* === UTILITY === */
.container{max-width:var(--w-max);margin:0 auto;padding:0 var(--s-gutter)}
.container-narrow{max-width:var(--w-narrow);margin:0 auto;padding:0 var(--s-gutter)}
.container-medium{max-width:var(--w-medium);margin:0 auto;padding:0 var(--s-gutter)}
.section{padding:var(--s-macro) 0}

/* === TYPOGRAPHY === */
h1,h2,h3,h4,.display{
  font-family:var(--font-display);font-weight:500;
  line-height:var(--lh-tight);letter-spacing:-.015em
}
h1{font-size:var(--fs-h1)}
h2{font-size:var(--fs-h2)}
h3{font-size:var(--fs-h3)}
h4{font-family:var(--font-text);font-size:var(--fs-h4);font-weight:600;letter-spacing:0}
p{text-wrap:pretty}
h1,h2,h3,h4{text-wrap:balance}

.label{
  display:inline-block;font-family:var(--font-text);
  font-size:var(--fs-label);font-weight:600;
  text-transform:uppercase;letter-spacing:.15em;
  color:var(--blue);margin-bottom:1rem
}
.label-line{
  display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem
}
.label-line::after{
  content:'';flex:1;height:1px;background:rgba(255,255,255,.06)
}

/* ================================================================
   NAVIGATION — gözden geçirilmiş
   ================================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;height:68px;
  background:rgba(12,13,20,.94);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:var(--hairline);
  transition:background .3s var(--ease-out)
}
.nav.scrolled{background:rgba(12,13,20,.98)}
.nav .container{
  display:flex;align-items:center;justify-content:space-between;height:100%
}
.nav-logo{
  font-family:var(--font-display);font-size:1.5rem;font-weight:600;
  color:var(--ink);letter-spacing:-.02em;
  transition:color .2s;position:relative;z-index:102
}
.nav-logo:hover{color:var(--blue)}

.nav-links{display:flex;align-items:center;gap:.5rem}
.nav-link{
  position:relative;padding:.4rem .85rem;font-size:var(--fs-small);
  font-weight:500;color:var(--stone);border-radius:var(--radius);
  transition:color .2s,background .2s
}
.nav-link:hover{color:var(--ink);background:rgba(255,255,255,.03)}
.nav-link.active{color:var(--ink)}
.nav-link.active::after{
  content:'';position:absolute;bottom:0;left:.85rem;right:.85rem;
  height:1.5px;background:var(--ink);border-radius:1px
}
.nav-sep{width:1px;height:18px;background:rgba(255,255,255,.07);margin:0 .25rem}
.nav-cta{margin-left:.5rem}

/* Hamburger */
.nav-toggle{
  display:none;flex-direction:column;gap:5px;
  padding:8px 4px;z-index:102;border-radius:var(--radius)
}
.nav-toggle span{
  display:block;width:20px;height:1.5px;background:var(--ink);
  border-radius:1px;transition:all .25s var(--ease)
}
.nav-toggle.active span:nth-child(1){transform:rotate(45deg) translate(4px,5px)}
.nav-toggle.active span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(4px,-5px)}

/* Mobile overlay */
.nav-overlay{
  display:none;position:fixed;inset:0;background:var(--paper);
  z-index:99;flex-direction:column;align-items:center;justify-content:center;
  gap:1.5rem;opacity:0;transition:opacity .3s var(--ease-out)
}
.nav-overlay.active{display:flex;opacity:1}
.nav-overlay a{
  font-family:var(--font-display);font-size:2.25rem;font-weight:500;
  color:var(--ink);transition:color .2s;padding:.25rem 0
}
.nav-overlay a:hover{color:var(--blue)}
.nav-overlay .nav-cta-btn{margin-top:.75rem}

/* ================================================================
   BUTTONS
   ================================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--font-text);font-weight:600;font-size:var(--fs-small);
  letter-spacing:.03em;padding:.75rem 1.75rem;border-radius:var(--radius);
  transition:all .2s var(--ease-out);cursor:pointer;text-decoration:none;
  position:relative;overflow:hidden
}
.btn::after{
  content:'';position:absolute;inset:0;background:transparent;
  transition:background .2s var(--ease-out);pointer-events:none
}
.btn-primary{background:var(--ink);color:var(--paper);border:1.5px solid var(--ink)}
.btn-primary:hover{background:var(--blue);border-color:var(--blue);transform:translateY(-1px);box-shadow:0 4px 12px rgba(51,85,204,.2)}
.btn-primary:active{transform:translateY(0)}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--paper);transform:translateY(-1px)}
.btn-outline:active{transform:translateY(0)}
.btn-sm{padding:.5rem 1.25rem;font-size:var(--fs-caption)}
.btn-lg{padding:1rem 2.25rem;font-size:var(--fs-body)}

/* ================================================================
   HERO
   ================================================================ */
.hero{
  min-height:100vh;display:flex;align-items:center;
  padding-top:68px;background:var(--paper);position:relative
}
.hero-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(2rem,6vw,5rem);align-items:center
}
.hero-text{max-width:540px}
.hero-text h1{
  font-size:var(--fs-hero);font-weight:600;line-height:.95;
  letter-spacing:-.025em;margin-bottom:1.5rem
}
.hero-text h1 em{font-style:italic;color:var(--blue)}
.hero-text .lead{
  font-size:1.2rem;color:var(--stone);line-height:var(--lh-relaxed);
  margin-bottom:2.5rem;max-width:440px
}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero-visual{
  position:relative;aspect-ratio:4/5;
  background:var(--blue-pale) url(../assets/hero.jpg) center/cover no-repeat;overflow:hidden
}
.hero-visual::after{
  content:'';position:absolute;inset:1.25rem;
  border:1px solid rgba(51,85,204,.15)
}

/* ================================================================
   SECTION HEADER
   ================================================================ */
.section-header{margin-bottom:clamp(2.5rem,5vw,3.5rem)}
.section-header h2{margin-bottom:.75rem}
.section-header p{color:var(--stone);max-width:480px;font-size:var(--fs-body)}
.section-header.center{text-align:center}
.section-header.center p{margin-inline:auto}

/* ================================================================
   SERVICE CARDS — 1px grid
   ================================================================ */
.card-grid-3{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--hairline);
  border-top:var(--hairline);border-bottom:var(--hairline)
}
.service-card{
  background:var(--paper);padding:var(--s-card);
  display:flex;flex-direction:column;
  transition:background .25s var(--ease-out);
  position:relative
}
.service-card:hover{background:var(--blue-glow)}
.service-card:hover .service-link::after{transform:translateX(4px)}
.service-card .num{
  font-family:var(--font-display);font-size:3.5rem;font-weight:500;
  color:var(--blue-pale);line-height:1;margin-bottom:1.5rem;
  transition:color .25s var(--ease-out)
}
.service-card:hover .num{color:rgba(51,85,204,.25)}
.service-card h3{margin-bottom:.75rem}
.service-card p{
  color:var(--stone);font-size:var(--fs-small);
  line-height:var(--lh-relaxed);flex:1;margin-bottom:1.5rem
}
.service-card .tag{
  display:inline-flex;align-items:center;gap:.35rem;
  font-family:var(--font-text);font-size:var(--fs-label);font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--blue);padding:.4rem .85rem;
  background:var(--blue-pale);align-self:flex-start
}
.service-link{
  display:inline-flex;align-items:center;gap:.35rem;
  font-size:var(--fs-small);font-weight:600;color:var(--ink);
  margin-top:1.25rem;transition:color .15s
}
.service-link:hover{color:var(--blue)}
.service-link::after{content:'→';transition:transform .2s var(--ease-out)}

/* ================================================================
   ABOUT
   ================================================================ */
.about-split{
  display:grid;grid-template-columns:1fr 1fr;
  gap:var(--s-macro);align-items:center
}
.about-visual{
  aspect-ratio:3/4;background:var(--ink-light) url(../assets/about.jpg) center/cover no-repeat;position:relative
}
.about-visual::before{
  content:'';position:absolute;
  top:-.75rem;left:-.75rem;right:.75rem;bottom:.75rem;
  border:1px solid var(--fog);z-index:-1
}
.about-text h2{margin-bottom:1.5rem}
.about-text p{color:var(--stone);margin-bottom:1rem;max-width:460px}
.stat-line{
  display:flex;gap:3rem;margin-top:2rem;padding-top:2rem;
  border-top:var(--hairline)
}
.stat-line dt{font-family:var(--font-display);font-size:2rem;color:var(--blue)}
.stat-line dd{font-size:var(--fs-small);color:var(--stone);margin-top:.25rem}

/* ================================================================
   TESTIMONIALS
   ================================================================ */
.testimonial-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-gutter)
}
.testimonial-card{
  padding:var(--s-card);border:var(--hairline);
  transition:border-color .2s,background .2s
}
.testimonial-card:hover{border-color:var(--blue);background:var(--blue-glow)}
.testimonial-card .stars{
  color:var(--blue);font-size:.7rem;letter-spacing:.2em;margin-bottom:1.25rem
}
.testimonial-card blockquote{
  font-family:var(--font-display);font-size:1.1rem;font-style:italic;
  line-height:var(--lh-relaxed);color:var(--ink);margin-bottom:1.5rem
}
.testimonial-card .author{display:flex;align-items:center;gap:.75rem}
.author-dot{width:40px;height:40px;border-radius:50%;background:var(--blue-pale)}
.author-name{font-size:var(--fs-small);font-weight:600}
.author-role{font-size:var(--fs-caption);color:var(--stone)}

/* ================================================================
   BLOG CARDS
   ================================================================ */
.blog-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-gutter)
}
.blog-card{
  border:var(--hairline);
  transition:border-color .25s,box-shadow .25s
}
.blog-card:hover{
  border-color:var(--blue);
  box-shadow:0 8px 24px rgba(255,255,255,.04)
}
.blog-card-thumb{aspect-ratio:3/2;background:var(--blue-pale) center/cover no-repeat;overflow:hidden}
.blog-card-body{padding:var(--s-inner)}
.blog-card .kicker{
  font-size:var(--fs-label);font-weight:600;text-transform:uppercase;
  letter-spacing:.1em;color:var(--blue);margin-bottom:.5rem
}
.blog-card h4{
  font-family:var(--font-display);font-size:1.2rem;font-weight:500;
  line-height:1.25;margin-bottom:.5rem;
  transition:color .15s
}
.blog-card:hover h4{color:var(--blue)}
.blog-card p{
  font-size:var(--fs-small);color:var(--stone);
  line-height:var(--lh-relaxed);margin-bottom:1rem
}
.blog-meta{font-size:var(--fs-caption);color:var(--fog)}

/* ================================================================
   CTA STRIP
   ================================================================ */
.cta-strip{
  background:var(--ink);color:var(--paper);
  padding:var(--s-macro) 0;text-align:center
}
.cta-strip h2{margin-bottom:1rem}
.cta-strip p{color:var(--fog);margin-bottom:2rem;max-width:480px;margin-inline:auto}
.cta-strip .btn-primary{
  background:var(--blue);color:#fff;border-color:var(--blue)
}
.cta-strip .btn-primary:hover{
  background:var(--paper);color:var(--ink);border-color:var(--paper)
}

/* ================================================================
   FOOTER
   ================================================================ */
/* ---- FOOTER (geliştirilmiş) — eski .footer* bloğunun YERİNE geçer ---- */
.footer{
  background:var(--ink);color:var(--fog);
  padding:5rem 0 2rem;font-size:var(--fs-small)
}
.footer .nav-logo{color:var(--paper);font-size:1.35rem;margin-bottom:.85rem;display:inline-block}
.footer-top{
  display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr 1.6fr;
  gap:2.5rem;margin-bottom:3rem
}
.footer-brand{max-width:340px}
.footer-tagline{margin:0 0 1.25rem;color:var(--fog);line-height:var(--lh-body)}
.footer-col h4{
  color:var(--paper);font-size:var(--fs-label);font-weight:600;
  text-transform:uppercase;letter-spacing:.12em;margin-bottom:1.1rem
}
.footer-links{display:flex;flex-direction:column;gap:.65rem}
.footer-links a{color:var(--fog);transition:color .15s;width:fit-content}
.footer-links a:hover{color:var(--paper)}
.footer-note{margin-top:1rem;color:var(--stone);font-size:var(--fs-caption)}
.footer-news-text{margin-bottom:1rem;line-height:var(--lh-body)}
.footer-newsletter{display:flex;gap:.5rem}
.footer-newsletter input{
  flex:1;min-width:0;padding:.65rem 1rem;background:transparent;
  border:1px solid rgba(12,13,20,.18);color:var(--paper);
  font-size:var(--fs-small);outline:none;border-radius:var(--radius);
  transition:border-color .2s
}
.footer-newsletter input::placeholder{color:var(--stone)}
.footer-newsletter input:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-glow)}
.footer-newsletter .btn{background:var(--blue);color:#fff;border:none;white-space:nowrap}
.footer-newsletter .btn:hover{background:var(--blue-deep)}
.footer-social{display:flex;gap:.9rem;margin-top:.25rem}
.footer-social a{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:50%;
  border:1px solid rgba(12,13,20,.18);color:var(--fog);
  transition:color .15s,border-color .15s,background .15s
}
.footer-social a:hover{color:var(--blue);border-color:var(--blue)}
.footer-bottom{
  padding-top:2rem;border-top:1px solid rgba(12,13,20,.12);
  display:flex;justify-content:space-between;align-items:center;
  font-size:var(--fs-caption);flex-wrap:wrap;gap:.75rem
}
.footer-bottom-links{display:flex;gap:1.5rem;flex-wrap:wrap}
.footer-bottom-links a{transition:color .15s}
.footer-bottom-links a:hover{color:var(--paper)}
.footer-top-link{transition:color .15s}
.footer-top-link:hover{color:var(--paper)}

/* ---- 4'lü hizmet kart ızgarası (.card-grid-3 ile aynı stil) ---- */
.card-grid-4{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--hairline);
  border-top:var(--hairline);border-bottom:var(--hairline)
}

/* ---- Hizmet satırı alt başlığı ---- */
.service-row-sub{
  color:var(--blue);font-size:var(--fs-small);font-style:italic;
  margin:.1rem 0 .6rem
}

/* ================================================================
   INNER PAGES
   ================================================================ */
.page-hero{
  padding:130px 0 80px;text-align:center;
  background:var(--paper);border-bottom:var(--hairline)
}
.page-hero-sm{padding:110px 0 60px}

/* Service Detail List */
.service-list{display:flex;flex-direction:column}
.service-row{
  display:grid;grid-template-columns:1fr 2fr auto;
  gap:2rem;align-items:center;padding:2.25rem 0;
  border-bottom:var(--hairline);
  transition:background .2s,padding-left .2s
}
.service-row:first-child{border-top:var(--hairline)}
.service-row:hover{background:var(--blue-glow);padding-left:1rem}
.service-row-num{
  font-family:var(--font-display);font-size:2.5rem;font-weight:500;
  color:var(--blue-pale);transition:color .2s
}
.service-row:hover .service-row-num{color:var(--blue)}
.service-row h3{margin-bottom:.5rem}
.service-row p{color:var(--stone);font-size:var(--fs-small);line-height:var(--lh-relaxed)}
.service-row-price{text-align:right}
.service-row-price .amount{font-family:var(--font-display);font-size:1.5rem;color:var(--ink)}
.service-row-price .period{font-size:var(--fs-caption);color:var(--stone);margin-top:.15rem}

/* Process */
.process-row{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--hairline);
  border-top:var(--hairline);border-bottom:var(--hairline)
}
.process-step{
  background:var(--paper);padding:2.5rem 1.75rem;text-align:center;
  transition:background .2s
}
.process-step:hover{background:var(--blue-glow)}
.process-step .step-num{
  font-family:var(--font-display);font-size:2.75rem;font-weight:500;
  color:var(--blue);margin-bottom:.75rem
}
.process-step h4{font-family:var(--font-text);font-size:var(--fs-small);margin-bottom:.5rem}
.process-step p{font-size:var(--fs-caption);color:var(--stone);line-height:1.6}

/* FAQ */
.faq-list{max-width:640px;margin:0 auto}
.faq-item{border-bottom:var(--hairline);cursor:pointer;transition:background .15s}
.faq-item:first-child{border-top:var(--hairline)}
.faq-item:hover{background:var(--blue-glow)}
.faq-question{
  display:flex;justify-content:space-between;align-items:center;
  padding:1.35rem 0;font-weight:500;gap:1rem
}
.faq-question .indicator{
  flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;
  justify-content:center;font-size:1.25rem;color:var(--blue);
  transition:transform .25s var(--ease)
}
.faq-item.open .faq-question .indicator{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .35s var(--ease-out),padding .35s var(--ease-out)}
.faq-item.open .faq-answer{max-height:300px;padding-bottom:1.25rem}
.faq-answer p{color:var(--stone);font-size:var(--fs-small);line-height:var(--lh-relaxed)}

/* Category Filter */
.category-bar{
  display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;
  margin-bottom:3rem;padding-bottom:.5rem
}
.category-pill{
  padding:.45rem 1.1rem;font-size:var(--fs-small);font-weight:500;
  color:var(--stone);background:transparent;
  border:1px solid var(--fog);border-radius:100px;
  cursor:pointer;transition:all .2s var(--ease-out)
}
.category-pill:hover{color:var(--ink);border-color:var(--ink)}
.category-pill.active{color:var(--paper);border-color:var(--ink);background:var(--ink)}

/* ================================================================
   CONTACT
   ================================================================ */
.contact-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem)}
.contact-form-box{padding:clamp(2rem,4vw,3rem);border:var(--hairline)}
.contact-form-box h3{font-family:var(--font-display);margin-bottom:2rem}
.form-group{margin-bottom:1.5rem}
.form-group label{
  display:block;font-size:var(--fs-label);font-weight:600;
  text-transform:uppercase;letter-spacing:.08em;
  color:var(--stone);margin-bottom:.5rem
}
.form-group input,
.form-group textarea,
.form-group select{
  width:100%;padding:.85rem 0;background:transparent;
  border:none;border-bottom:1.5px solid var(--fog);
  font-size:var(--fs-body);outline:none;
  transition:border-color .2s,padding-left .2s
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus{
  border-bottom-color:var(--blue);padding-left:.25rem
}
.form-group input.error,
.form-group textarea.error{border-bottom-color:#D44}
.form-group textarea{resize:vertical;min-height:100px}
.form-group select{
  appearance:none;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%238B8680' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E") no-repeat right .2rem center;
  padding-right:1.5rem
}
.form-submit{margin-top:2.25rem}
.form-message{display:none;margin-top:1rem;font-size:var(--fs-small);padding:.85rem 1rem;border-radius:var(--radius)}
.form-message.success{display:block;background:#EAF5EA;color:#1B5E1B;border:1px solid rgba(27,94,27,.15)}
.form-message.error{display:block;background:#FDF0F0;color:#8B1A1A;border:1px solid rgba(139,26,26,.1)}

.contact-details{display:flex;flex-direction:column;gap:1.25rem}
.contact-item{
  display:flex;gap:1rem;align-items:flex-start;
  padding:1rem;border:var(--hairline);transition:border-color .2s
}
.contact-item:hover{border-color:var(--blue)}
.contact-item-icon{
  width:44px;height:44px;flex-shrink:0;display:flex;
  align-items:center;justify-content:center;
  font-size:1.1rem;background:var(--blue-pale);color:var(--blue)
}
.contact-item h4{font-size:var(--fs-small);margin-bottom:.2rem}
.contact-item p{font-size:var(--fs-small);color:var(--stone)}
.contact-hours-box{margin-top:.5rem;padding:1.5rem;border:var(--hairline)}
.contact-hours-box h4{
  font-size:var(--fs-label);text-transform:uppercase;
  letter-spacing:.08em;color:var(--stone);margin-bottom:1rem
}
.hours-row{
  display:flex;justify-content:space-between;padding:.45rem 0;
  font-size:var(--fs-small);color:var(--stone);
  border-bottom:1px solid rgba(255,255,255,.04)
}
.hours-row:last-child{border-bottom:none}

/* ================================================================
   VALUES
   ================================================================ */
.values-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--hairline);
  border-top:var(--hairline)
}
.value-card{
  background:var(--paper);padding:2.5rem;
  transition:background .2s
}
.value-card:hover{background:var(--blue-glow)}
.value-card .value-num{
  font-family:var(--font-display);font-size:3.5rem;font-weight:500;
  color:var(--blue-pale);margin-bottom:1rem;transition:color .2s
}
.value-card:hover .value-num{color:rgba(51,85,204,.25)}
.value-card h4{margin-bottom:.5rem}
.value-card p{font-size:var(--fs-small);color:var(--stone);line-height:var(--lh-relaxed)}

/* ================================================================
   ANIMATIONS — scroll reveal
   ================================================================ */
.animate-in{
  opacity:0;transform:translateY(24px);
  transition:opacity .6s var(--ease-out),transform .6s var(--ease-out)
}
.animate-in.visible{opacity:1;transform:translateY(0)}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width:1023px){
  .hero-grid{grid-template-columns:1fr}
  .hero-visual{display:none}
  .card-grid-3{grid-template-columns:repeat(2,1fr)}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .testimonial-grid{grid-template-columns:repeat(2,1fr)}
  .about-split{grid-template-columns:1fr}
  .contact-split{grid-template-columns:1fr}
  .footer-top{grid-template-columns:repeat(2,1fr)}
  .footer-brand{grid-column:1/-1;max-width:none}
  .card-grid-4{grid-template-columns:repeat(2,1fr)}
  .process-row{grid-template-columns:repeat(2,1fr)}
  .values-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:767px){
  .nav-links,.nav-sep,.nav-cta{display:none}
  .nav-toggle{display:flex}
  .card-grid-3{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .testimonial-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .card-grid-4{grid-template-columns:1fr}
  .process-row{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr}
  .service-row{grid-template-columns:1fr;text-align:center}
  .service-row:hover{padding-left:0}
  .service-row-price{text-align:center}
  .hero-text h1{font-size:clamp(2.5rem,8vw,3.5rem)}
  .footer-bottom{flex-direction:column;text-align:center}
}
