@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,300&display=swap');

/* ═══════════════════ TOKENS ═══════════════════ */
:root {
  --bg:            #f8f6f2;
  --bg-2:          #f0ece4;
  --bg-3:          #e8e3d8;
  --surface:       #ffffff;
  --border:        rgba(0,0,0,0.08);
  --border-strong: rgba(0,0,0,0.14);
  --text-primary:  #1a1814;
  --text-secondary:#5a5650;
  --text-tertiary: #8a8680;
  --accent:        #1a1814;
  --accent-light:  rgba(26,24,20,0.07);
  --accent-warm:   #c8602a;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.06),0 1px 2px rgba(0,0,0,0.04);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.08),0 2px 6px rgba(0,0,0,0.04);
  --shadow-lg: 0 12px 40px rgba(0,0,0,0.12),0 4px 12px rgba(0,0,0,0.06);
  --shadow-xl: 0 24px 64px rgba(0,0,0,0.16),0 8px 24px rgba(0,0,0,0.08);
  --radius-sm:   8px;
  --radius-md:  14px;
  --radius-lg:  20px;
  --radius-xl:  28px;
  --radius-pill:9999px;
  --nav-height: 72px;
  --ease: cubic-bezier(0.4,0,0.2,1);
  --spring: cubic-bezier(0.34,1.56,0.64,1);
}

[data-theme="dark"] {
  --bg:            #111009;
  --bg-2:          #181610;
  --bg-3:          #201e17;
  --surface:       #1e1b14;
  --border:        rgba(255,255,255,0.08);
  --border-strong: rgba(255,255,255,0.13);
  --text-primary:  #f0ece3;
  --text-secondary:#9a9488;
  --text-tertiary: #6a6460;
  --accent:        #f0ece3;
  --accent-light:  rgba(240,236,227,0.08);
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.4);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.5);
  --shadow-lg: 0 12px 40px rgba(0,0,0,0.6);
  --shadow-xl: 0 24px 64px rgba(0,0,0,0.7);
}

/* ═══════════════════ RESET ═══════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
body{
  font-family:'DM Sans',sans-serif;
  background:var(--bg);color:var(--text-primary);
  line-height:1.6;overflow-x:hidden;
  transition:background .3s ease,color .3s ease;
}
/* noise overlay */
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:9999;
  opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px 180px;
}
[data-theme="dark"] body::before{opacity:.05}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{cursor:pointer;border:none;background:none;font-family:inherit}
ul{list-style:none}
::selection{background:var(--accent-warm);color:#fff}

/* ═══════════════════ LAYOUT ═══════════════════ */
.container{width:100%;max-width:1180px;margin:0 auto;padding:0 24px}
@media(min-width:768px){.container{padding:0 40px}}
@media(min-width:1200px){.container{padding:0 48px}}

/* ═══════════════════ TYPE ═══════════════════ */
h1,h2,h3,h4{font-family:'DM Serif Display',serif;line-height:1.15;letter-spacing:-.02em}
.section-label{display:inline-block;font-family:'DM Sans',sans-serif;font-size:11px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--accent-warm);margin-bottom:16px}
.section-title{font-size:clamp(30px,5vw,52px);margin-bottom:20px}
.section-sub{font-size:18px;color:var(--text-secondary);max-width:540px;line-height:1.65;font-weight:300}
.section-header{margin-bottom:64px}

/* ═══════════════════ BUTTONS ═══════════════════ */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:var(--radius-pill);font-family:'DM Sans',sans-serif;font-size:15px;font-weight:500;text-decoration:none;transition:all .22s var(--ease);white-space:nowrap}
.btn:focus-visible{outline:2px solid var(--accent-warm);outline-offset:3px}
.btn--primary{background:var(--text-primary);color:var(--bg)}
.btn--primary:hover{background:var(--accent-warm);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn--ghost{background:transparent;color:var(--text-primary);border:1.5px solid var(--border-strong)}
.btn--ghost:hover{background:var(--accent-light);border-color:var(--text-primary);transform:translateY(-2px)}
.btn--lg{padding:16px 32px;font-size:16px}

/* ═══════════════════ NAVBAR ═══════════════════ */
.navbar{position:sticky;top:0;z-index:100;height:var(--nav-height);backdrop-filter:blur(18px) saturate(180%);-webkit-backdrop-filter:blur(18px) saturate(180%);background:rgba(248,246,242,.88);border-bottom:1px solid var(--border);transition:background .3s,border-color .3s}
[data-theme="dark"] .navbar{background:rgba(17,16,9,.88)}
.navbar__inner{height:100%;display:flex;align-items:center;gap:32px}
.navbar__logo{flex-shrink:0;display:flex;align-items:center;transition:opacity .22s var(--ease)}
.navbar__logo:hover{opacity:.75}
.navbar__logo:focus-visible{outline:2px solid var(--accent-warm);outline-offset:4px;border-radius:4px}
.logo-mark{display:flex;align-items:center;flex-shrink:0}
.logo-wordmark{display:flex;align-items:baseline;gap:5px;margin-left:10px}
.logo-wordmark__name{font-family:'DM Serif Display',serif;font-size:19px;letter-spacing:-.3px;color:var(--text-primary);line-height:1;transition:color .3s}
.logo-wordmark__sub{font-family:'DM Sans',sans-serif;font-size:10px;font-weight:600;letter-spacing:2.8px;color:var(--text-tertiary);text-transform:uppercase}
.navbar__nav{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav-link{padding:8px 14px;border-radius:var(--radius-pill);font-size:14px;font-weight:500;color:var(--text-secondary);transition:all .22s var(--ease)}
.nav-link:hover,.nav-link.active{color:var(--text-primary);background:var(--accent-light)}
.nav-link:focus-visible{outline:2px solid var(--accent-warm);outline-offset:2px}
.navbar__actions{display:flex;align-items:center;gap:10px}

/* lang switcher */
.lang-switcher{display:flex;align-items:center;gap:2px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-pill);padding:3px}
.lang-btn{padding:5px 10px;border-radius:var(--radius-pill);font-size:11px;font-weight:600;letter-spacing:.5px;color:var(--text-tertiary);background:transparent;transition:all .22s var(--ease);line-height:1}
.lang-btn:hover{color:var(--text-primary)}
.lang-btn.active{background:var(--surface);color:var(--text-primary);box-shadow:var(--shadow-sm)}
.lang-btn:focus-visible{outline:2px solid var(--accent-warm);outline-offset:1px}
.mobile-lang{display:flex;gap:8px;margin-top:20px;padding:0 16px}
.mobile-lang .lang-btn{flex:1;text-align:center;padding:10px;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);font-size:13px;border-radius:var(--radius-md)}
.mobile-lang .lang-btn.active{background:var(--accent-warm);border-color:var(--accent-warm);color:#fff}

/* theme toggle */
.theme-toggle{width:38px;height:38px;border-radius:var(--radius-pill);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .22s var(--ease)}
.theme-toggle:hover{background:var(--accent-light);color:var(--text-primary)}
.theme-toggle:focus-visible{outline:2px solid var(--accent-warm)}
.icon-sun{display:block}.icon-moon{display:none}
[data-theme="dark"] .icon-sun{display:none}[data-theme="dark"] .icon-moon{display:block}

/* hamburger */
.navbar__hamburger{display:none;flex-direction:column;gap:5px;padding:6px;width:38px;height:38px;border-radius:var(--radius-sm);justify-content:center;align-items:center;transition:background .22s}
.navbar__hamburger:hover{background:var(--accent-light)}
.navbar__hamburger:focus-visible{outline:2px solid var(--accent-warm)}
.navbar__hamburger span{display:block;width:20px;height:1.5px;background:var(--text-primary);border-radius:2px;transition:all .22s var(--ease)}

/* mobile menu */
.mobile-menu{position:fixed;top:var(--nav-height);left:0;right:0;background:var(--bg);border-bottom:1px solid var(--border);padding:20px 24px 28px;transform:translateY(-110%);opacity:0;transition:transform .3s ease,opacity .3s ease;z-index:99;pointer-events:none}
.mobile-menu.open{transform:translateY(0);opacity:1;pointer-events:all}
.mobile-menu nav{display:flex;flex-direction:column;gap:4px}
.mobile-link{padding:14px 16px;border-radius:var(--radius-md);font-size:18px;font-weight:500;color:var(--text-primary);transition:background .22s}
.mobile-link:hover{background:var(--accent-light)}

/* ═══════════════════ HERO ═══════════════════ */
.hero{min-height:calc(100svh - var(--nav-height));display:flex;align-items:center;position:relative;overflow:hidden;padding:100px 0 80px}
.hero__glow{position:absolute;border-radius:50%;filter:blur(100px);pointer-events:none}
.hero__glow--1{width:600px;height:600px;background:radial-gradient(circle,rgba(200,96,42,.12) 0%,transparent 70%);top:-100px;right:-100px;animation:glow-drift 8s ease-in-out infinite}
.hero__glow--2{width:400px;height:400px;background:radial-gradient(circle,rgba(26,24,20,.06) 0%,transparent 70%);bottom:0;left:-50px;animation:glow-drift 10s ease-in-out infinite reverse}
[data-theme="dark"] .hero__glow--1{background:radial-gradient(circle,rgba(200,96,42,.22) 0%,transparent 70%)}
@keyframes glow-drift{0%,100%{transform:translate(0,0)}50%{transform:translate(30px,20px)}}
.hero__inner{position:relative;z-index:1;max-width:800px}
.eyebrow-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--radius-pill);border:1.5px solid var(--border-strong);font-size:12px;font-weight:500;color:var(--text-secondary);letter-spacing:.5px;margin-bottom:32px}
.eyebrow-badge::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--accent-warm);animation:pulse-dot 2s ease-in-out infinite;flex-shrink:0}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}
.hero__headline{font-size:clamp(44px,7vw,84px);line-height:1.07;letter-spacing:-.03em;margin-bottom:28px}
.hero__headline em{font-style:italic;color:var(--accent-warm)}
.hero__sub{font-size:clamp(17px,2vw,20px);color:var(--text-secondary);max-width:520px;line-height:1.65;font-weight:300;margin-bottom:40px}
.hero__ctas{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:48px}
.hero__chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius-pill);background:var(--surface);border:1px solid var(--border);font-size:13px;font-weight:500;color:var(--text-secondary);transition:all .22s var(--ease)}
.chip:hover{border-color:var(--border-strong);color:var(--text-primary);transform:translateY(-1px)}
.hero__scroll-indicator{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-line{width:1px;height:48px;background:linear-gradient(to bottom,var(--border-strong),transparent);animation:scroll-pulse 1.8s ease-in-out infinite}
@keyframes scroll-pulse{0%,100%{transform:scaleY(1);opacity:1}50%{transform:scaleY(.5);opacity:.4}}
.scroll-text{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--text-tertiary);font-weight:500}

/* ═══════════════════ FADE-IN ═══════════════════ */
.fade-in{opacity:0;transform:translateY(22px);transition:opacity .6s ease var(--delay,0s),transform .6s ease var(--delay,0s)}
.fade-in.visible{opacity:1;transform:none}

/* ═══════════════════ PORTFOLIO ═══════════════════ */
.work{padding:120px 0;background:var(--bg-2)}
.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:24px}
.project-card{background:var(--surface);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);cursor:pointer;transition:transform .22s var(--ease),box-shadow .22s var(--ease);display:flex;flex-direction:column}
.project-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.project-card:focus-visible{outline:2px solid var(--accent-warm);outline-offset:3px}
.project-card__visual{height:240px;position:relative;overflow:hidden;flex-shrink:0}
.mock{position:absolute;inset:16px;border-radius:8px;background:rgba(255,255,255,.06);overflow:hidden}
.mock--dashboard{display:flex;flex-direction:column}
.mock-bar{height:28px;background:rgba(255,255,255,.1);margin-bottom:8px;border-radius:4px}
.mock-sidebar{position:absolute;top:36px;left:0;width:55px;bottom:0;background:rgba(255,255,255,.07);border-radius:0 0 0 8px}
.mock-content{position:absolute;left:63px;top:36px;right:0;bottom:0;display:flex;flex-direction:column;gap:8px;padding:8px}
.mock-stat{height:40px;background:rgba(255,255,255,.12);border-radius:6px}
.mock-chart{flex:1;background:rgba(255,255,255,.06);border-radius:6px;position:relative}
.mock-chart::after{content:'';position:absolute;bottom:8px;left:4px;right:4px;height:40%;background:linear-gradient(135deg,rgba(37,99,235,.5),rgba(37,99,235,.1));border-radius:4px}
.mock--editorial .mock-image-lg{height:55%;background:rgba(255,255,255,.12);border-radius:6px;margin-bottom:10px}
.mock-line{height:10px;background:rgba(255,255,255,.2);border-radius:3px;margin-bottom:6px}
.mock-line--short{width:60%}
.mock-line--white{background:rgba(255,255,255,.6)}
.mock--tech .mock-hero-text{height:18px;width:80%;background:rgba(255,255,255,.25);border-radius:4px;margin-bottom:8px}
.mock--tech .mock-hero-sub{height:10px;width:60%;background:rgba(255,255,255,.15);border-radius:3px;margin-bottom:20px}
.mock-btn-row{display:flex;gap:8px}
.mock-btn{height:28px;width:80px;background:rgba(255,255,255,.9);border-radius:14px}
.mock-btn--ghost{background:transparent;border:1.5px solid rgba(255,255,255,.4)}
.mock--ecomm .mock-product-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;height:100%}
.mock-product{background:rgba(255,255,255,.12);border-radius:6px}
.mock--arch{position:relative}
.mock-fullscreen-img{position:absolute;inset:0;background:rgba(255,255,255,.06);border-radius:8px}
.mock-overlay-text{position:absolute;bottom:12px;left:12px;right:12px}
.mock--health .mock-card-ui{display:flex;align-items:center;gap:10px;padding:10px;background:rgba(255,255,255,.1);border-radius:8px;margin-bottom:12px}
.mock-avatar{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.25);flex-shrink:0}
.mock-info{flex:1}
.mock-progress-bars{display:flex;flex-direction:column;gap:8px;padding:0 4px}
.mock-progress{height:8px;background:rgba(45,212,191,.5);border-radius:4px}
.mock-progress--half{width:60%}
.mock-progress--three-quarter{width:80%}
.project-card__info{padding:24px;flex:1;display:flex;flex-direction:column}
.project-card__tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.tag{font-size:11px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;padding:3px 10px;border-radius:var(--radius-pill);background:var(--bg-2);color:var(--text-secondary);border:1px solid var(--border)}
.project-card__title{font-size:22px;font-family:'DM Serif Display',serif;margin-bottom:8px}
.project-card__desc{font-size:14px;color:var(--text-secondary);line-height:1.6;flex:1}
.project-card__cta{display:inline-block;margin-top:18px;font-size:13px;font-weight:600;color:var(--accent-warm);transition:letter-spacing .22s var(--ease)}
.project-card:hover .project-card__cta{letter-spacing:1px}

/* ═══════════════════ SERVICES ═══════════════════ */
.services{padding:120px 0}
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:20px}
.service-card{padding:36px 32px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:transform .22s var(--ease),box-shadow .22s var(--ease),border-color .22s var(--ease)}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--border-strong)}
.service-card__icon{width:52px;height:52px;border-radius:var(--radius-md);background:var(--accent-light);display:flex;align-items:center;justify-content:center;margin-bottom:22px}
.service-card__title{font-size:20px;font-family:'DM Serif Display',serif;margin-bottom:12px}
.service-card__desc{font-size:14px;color:var(--text-secondary);line-height:1.65;margin-bottom:18px}
.service-card__list{display:flex;flex-direction:column;gap:8px}
.service-card__list li{font-size:13px;color:var(--text-secondary);display:flex;align-items:center;gap:8px}
.service-card__list li::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--accent-warm);flex-shrink:0}

/* ═══════════════════ PROCESS ═══════════════════ */
.process{padding:120px 0;background:var(--bg-2)}
.process-timeline{display:flex;flex-direction:column;max-width:680px}
.process-step{display:grid;grid-template-columns:52px 32px 1fr;gap:0 20px;align-items:start;padding-bottom:48px}
.process-step__number{font-family:'DM Serif Display',serif;font-size:14px;color:var(--accent-warm);text-align:right;padding-top:2px}
.process-step__line{width:1px;background:var(--border-strong);align-self:stretch;margin:0 auto;position:relative}
.process-step__line::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:11px;height:11px;border-radius:50%;background:var(--accent-warm);border:2px solid var(--bg-2)}
.process-step__line--last{background:linear-gradient(to bottom,var(--border-strong),transparent)}
.process-step__content h3{font-size:24px;font-family:'DM Serif Display',serif;margin-bottom:10px}
.process-step__content p{font-size:15px;color:var(--text-secondary);line-height:1.65}

/* ═══════════════════ TESTIMONIALS ═══════════════════ */
.testimonials{padding:120px 0}
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.testimonial{padding:34px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:transform .22s var(--ease),box-shadow .22s var(--ease)}
.testimonial:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.testimonial__stars{color:var(--accent-warm);font-size:14px;letter-spacing:2px;margin-bottom:18px}
.testimonial__quote{font-size:16px;color:var(--text-primary);line-height:1.7;font-style:italic;font-family:'DM Serif Display',serif;margin-bottom:26px;font-weight:400}
.testimonial__author{display:flex;align-items:center;gap:14px}
.testimonial__avatar{width:44px;height:44px;border-radius:50%;background:var(--accent-warm);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;font-family:'DM Sans',sans-serif;flex-shrink:0}
.testimonial__name{display:block;font-family:'DM Sans',sans-serif;font-weight:600;font-size:14px;font-style:normal;color:var(--text-primary)}
.testimonial__role{font-size:13px;color:var(--text-tertiary)}

/* ═══════════════════ ABOUT ═══════════════════ */
.about{padding:120px 0;background:var(--bg-2)}
.about__inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.about__text .section-label{display:block}
.about__text .section-title{margin-bottom:28px}
.about__text p{font-size:16px;color:var(--text-secondary);line-height:1.75;margin-bottom:18px;font-weight:300}
.about__stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:34px}
.about__stat{padding:26px 22px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}
.about__stat-num{display:block;font-family:'DM Serif Display',serif;font-size:38px;color:var(--text-primary);line-height:1;margin-bottom:6px}
.about__stat-label{font-size:13px;color:var(--text-tertiary)}
.about__tools-label{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:14px}
.tools-chips{display:flex;flex-wrap:wrap;gap:8px}
.tool-chip{padding:6px 14px;border-radius:var(--radius-pill);border:1px solid var(--border);font-size:13px;font-weight:500;color:var(--text-secondary);background:var(--surface);transition:all .22s var(--ease)}
.tool-chip:hover{border-color:var(--accent-warm);color:var(--accent-warm)}

/* ═══════════════════ CONTACT ═══════════════════ */
.contact{padding:120px 0}
.contact-card{display:grid;grid-template-columns:1fr 1fr;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg)}
.contact-card__left{padding:52px 44px;display:flex;flex-direction:column;gap:34px;border-right:1px solid var(--border)}
.contact-card__right{padding:52px 44px;background:var(--bg-2);display:flex;flex-direction:column;justify-content:space-between}
.contact-detail{display:flex;align-items:flex-start;gap:16px}
.contact-detail__icon{width:40px;height:40px;border-radius:var(--radius-sm);background:var(--accent-light);display:flex;align-items:center;justify-content:center;color:var(--text-primary);flex-shrink:0}
.contact-detail__label{display:block;font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:4px}
.contact-detail__value{display:block;font-size:16px;font-weight:500;color:var(--text-primary);transition:color .22s}
a.contact-detail__value:hover{color:var(--accent-warm)}
.copy-btn{margin-top:8px;padding:5px 12px;border-radius:var(--radius-pill);background:var(--bg-2);border:1px solid var(--border);font-size:12px;font-weight:600;color:var(--text-secondary);transition:all .22s var(--ease)}
.copy-btn:hover{background:var(--accent-warm);border-color:var(--accent-warm);color:#fff}
.copy-btn:focus-visible{outline:2px solid var(--accent-warm);outline-offset:2px}
.contact-card__social-label{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:18px}
.social-links{display:flex;flex-direction:column;gap:12px}
.social-link{display:inline-flex;align-items:center;gap:12px;font-size:15px;font-weight:500;color:var(--text-primary);padding:10px 14px;border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--border);transition:all .22s var(--ease)}
.social-link:hover{border-color:var(--accent-warm);color:var(--accent-warm);transform:translateX(4px)}
.social-link:focus-visible{outline:2px solid var(--accent-warm);outline-offset:2px}
.contact-card__availability{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text-secondary);font-weight:500;margin-top:32px;padding:14px 18px;background:var(--surface);border-radius:var(--radius-md);border:1px solid var(--border)}
.availability-dot{width:8px;height:8px;border-radius:50%;background:#22c55e;animation:pulse-dot 2s ease-in-out infinite;flex-shrink:0}

/* ═══════════════════ FOOTER ═══════════════════ */
.footer{padding:40px 0;border-top:1px solid var(--border);background:var(--bg-2)}
.footer__inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px}
.footer__logo{display:flex;align-items:center;gap:12px;transition:opacity .22s var(--ease)}
.footer__logo:hover{opacity:.7}
.footer__logo:focus-visible{outline:2px solid var(--accent-warm);outline-offset:4px;border-radius:4px}
.footer__wordmark{font-family:'DM Serif Display',serif;font-size:16px;color:var(--text-primary)}
.footer__nav{display:flex;flex-wrap:wrap;gap:4px}
.footer__nav a{padding:6px 12px;font-size:14px;color:var(--text-tertiary);border-radius:var(--radius-pill);transition:all .22s var(--ease)}
.footer__nav a:hover{color:var(--text-primary);background:var(--accent-light)}
.footer__nav a:focus-visible{outline:2px solid var(--accent-warm)}
.footer__copy{font-size:13px;color:var(--text-tertiary)}

/* ═══════════════════ MODAL ═══════════════════ */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .3s ease}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--surface);border-radius:var(--radius-xl);width:100%;max-width:760px;max-height:90vh;overflow-y:auto;position:relative;transform:scale(.95) translateY(20px);transition:transform .35s var(--spring);box-shadow:var(--shadow-xl);border:1px solid var(--border);scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}
.modal-overlay.open .modal{transform:scale(1) translateY(0)}
.modal__close{position:absolute;top:16px;right:16px;z-index:10;width:36px;height:36px;border-radius:50%;background:var(--bg-2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .22s var(--ease)}
.modal__close:hover{background:var(--bg-3);color:var(--text-primary)}
.modal__close:focus-visible{outline:2px solid var(--accent-warm);outline-offset:2px}
.modal__preview{height:280px;border-radius:var(--radius-xl) var(--radius-xl) 0 0;overflow:hidden;position:relative}
.modal__preview-mock{position:absolute;inset:20px;background:rgba(255,255,255,.08);border-radius:12px}
.modal__body{padding:36px 40px 40px}
.modal__tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.modal__title{font-size:32px;font-family:'DM Serif Display',serif;margin-bottom:16px}
.modal__desc{font-size:16px;color:var(--text-secondary);line-height:1.7;margin-bottom:30px;font-weight:300}
.modal__details{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:34px}
.modal__detail-col{padding:18px;background:var(--bg-2);border-radius:var(--radius-md);border:1px solid var(--border)}
.modal__detail-col h4{font-family:'DM Sans',sans-serif;font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:8px}
.modal__detail-col p{font-size:14px;color:var(--text-secondary);line-height:1.6}

/* ═══════════════════ TOAST ═══════════════════ */
.toast{position:fixed;bottom:32px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--text-primary);color:var(--bg);padding:14px 24px;border-radius:var(--radius-pill);font-size:14px;font-weight:500;opacity:0;pointer-events:none;transition:all .3s var(--spring);z-index:2000;box-shadow:var(--shadow-lg);white-space:nowrap}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ═══════════════════ RESPONSIVE ═══════════════════ */
@media(max-width:900px){
  .about__inner{grid-template-columns:1fr;gap:48px}
  .contact-card{grid-template-columns:1fr}
  .contact-card__left{border-right:none;border-bottom:1px solid var(--border);padding:38px 30px}
  .contact-card__right{padding:38px 30px}
  .modal__details{grid-template-columns:1fr}
}
@media(max-width:768px){
  .navbar__nav{display:none}
  .navbar__hamburger{display:flex}
  .navbar__actions .btn--primary{display:none}
  .hero{padding:60px 0 100px}
  .work,.services,.process,.testimonials,.about,.contact{padding:80px 0}
  .section-header{margin-bottom:40px}
  .portfolio-grid,.services-grid,.testimonials-grid{grid-template-columns:1fr}
  .process-step{grid-template-columns:40px 24px 1fr;gap:0 12px}
  .footer__inner{flex-direction:column;align-items:flex-start}
  .footer__nav{display:none}
  .modal__body{padding:24px}
  .modal__preview{height:200px}
  .hero__scroll-indicator{display:none}
}
@media(max-width:480px){
  .hero__ctas{flex-direction:column}
  .hero__ctas .btn{width:100%;justify-content:center}
  .about__stat-grid{grid-template-columns:1fr 1fr}
  .contact-card__left,.contact-card__right{padding:28px 20px}
}
