/* ============================================
   체크나우 — Design System v2
   Premium Typography · Slide Motion · Minimal
   ============================================ */

/* ---------- Design Tokens ---------- */
:root{
  --pri:#0F2B5B; --pri-l:#1A3F7A; --pri-d:#091D3E;
  --acc:#2563EB; --acc-l:#3B82F6; --acc-h:#1D4ED8;
  --white:#fff; --off:#F8FAFC;
  --g50:#F1F5F9; --g100:#E2E8F0; --g200:#CBD5E1;
  --g300:#94A3B8; --g400:#64748B; --g500:#475569;
  --g600:#334155; --g700:#1E293B; --g800:#0F172A;
  --font-body:'Noto Sans KR',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-display:'Playfair Display','Noto Sans KR',serif;
  --font-ui:'Inter','Noto Sans KR',sans-serif;
  --max:1240px; --pad:1.25rem; --hh:68px;
  --ease:cubic-bezier(.4,0,.2,1);
  --shadow-s:0 1px 3px rgba(15,23,42,.05);
  --shadow-m:0 8px 30px rgba(15,23,42,.08);
  --shadow-l:0 20px 60px rgba(15,23,42,.12);
  --r-sm:8px; --r-md:14px; --r-lg:20px; --r-xl:28px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:var(--hh);-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);font-size:16px;line-height:1.75;color:var(--g600);background:var(--white);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .2s var(--ease)}
ul,ol{list-style:none}
.container{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}

/* ---------- Utility Animations ---------- */
[data-animate]{opacity:0;transform:translateY(40px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-animate].is-visible{opacity:1;transform:translateY(0)}
[data-animate][data-delay="100"]{transition-delay:.1s}
[data-animate][data-delay="200"]{transition-delay:.2s}
[data-animate][data-delay="300"]{transition-delay:.3s}

@keyframes grain{0%,100%{transform:translate(0)}10%{transform:translate(-5%,-10%)}30%{transform:translate(3%,5%)}50%{transform:translate(-3%,12%)}70%{transform:translate(8%,-5%)}90%{transform:translate(-2%,8%)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes pulse-ring{0%{transform:scale(.8);opacity:1}100%{transform:scale(2.2);opacity:0}}

/* ============================================
   HEADER
   ============================================ */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--hh);background:rgba(255,255,255,.88);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid transparent;transition:all .3s var(--ease)}
.site-header.is-scrolled{background:rgba(255,255,255,.97);border-bottom-color:var(--g100);box-shadow:var(--shadow-s)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--hh);gap:1rem}

/* Logo */
.logo{display:flex;align-items:center;gap:.55rem;flex-shrink:0}
.logo-mark{display:grid;place-items:center;width:34px;height:34px;background:var(--pri);color:var(--white);border-radius:var(--r-sm);font-family:var(--font-ui);font-size:.95rem;font-weight:800;line-height:1}
.logo-text{font-family:var(--font-ui);font-size:1.25rem;font-weight:800;color:var(--pri);letter-spacing:-.03em}
.logo--light .logo-mark{background:rgba(255,255,255,.12)}
.logo--light .logo-text{color:var(--white)}

/* Nav */
.main-nav{display:none}
.nav-list{display:flex;gap:2px}
.nav-link{padding:.45rem .75rem;font-size:.875rem;font-weight:500;color:var(--g400);border-radius:var(--r-sm);transition:all .2s var(--ease);white-space:nowrap}
.nav-link:hover,.nav-link.is-active{color:var(--pri);background:var(--g50)}

/* Header CTA */
.header-cta{display:none;align-items:center;gap:.4rem;padding:.5rem 1.1rem;background:var(--pri);color:var(--white);font-size:.85rem;font-weight:600;border-radius:9999px;transition:all .2s var(--ease);white-space:nowrap}
.header-cta:hover{background:var(--pri-l);color:var(--white);transform:translateY(-1px);box-shadow:0 4px 14px rgba(15,43,91,.3)}
.header-cta i{font-size:.75rem}

/* Mobile */
.mobile-menu-btn{display:flex;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;background:none;border:none;cursor:pointer;padding:8px;border-radius:var(--r-sm)}
.mobile-menu-btn span{display:block;width:20px;height:2px;background:var(--g700);border-radius:2px;transition:all .3s var(--ease)}
.mobile-menu-btn.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.mobile-menu-btn.is-open span:nth-child(2){opacity:0}
.mobile-menu-btn.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-nav{position:fixed;top:var(--hh);left:0;right:0;background:var(--white);border-bottom:1px solid var(--g100);box-shadow:var(--shadow-l);padding:1.5rem;transform:translateY(-110%);opacity:0;visibility:hidden;transition:all .35s var(--ease);z-index:999}
.mobile-nav.is-open{transform:translateY(0);opacity:1;visibility:visible}
.mobile-nav-list{display:flex;flex-direction:column;gap:4px;margin-bottom:1rem}
.mobile-nav-list a{display:block;padding:.7rem 1rem;font-size:.95rem;font-weight:500;color:var(--g600);border-radius:var(--r-sm)}
.mobile-nav-list a:hover{background:var(--g50);color:var(--pri)}
.mobile-cta{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.85rem;background:var(--pri);color:var(--white);font-weight:600;border-radius:var(--r-md)}
.mobile-cta:hover{background:var(--pri-l);color:var(--white)}

/* ============================================
   BUTTONS
   ============================================ */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1.4rem;font-family:var(--font-body);font-size:.9rem;font-weight:600;border:none;border-radius:var(--r-md);cursor:pointer;transition:all .25s var(--ease);white-space:nowrap;line-height:1.4}
.btn i{font-size:.8em}
.btn--lg{padding:.85rem 1.8rem;font-size:.95rem}
.btn--primary{background:linear-gradient(135deg,var(--acc),var(--acc-h));color:var(--white);box-shadow:0 2px 10px rgba(37,99,235,.3)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(37,99,235,.35);color:var(--white)}
.btn--ghost{background:transparent;color:var(--white);border:1.5px solid rgba(255,255,255,.25)}
.btn--ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.45);color:var(--white)}
.btn--white{background:var(--white);color:var(--pri);box-shadow:0 2px 10px rgba(0,0,0,.08)}
.btn--white:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.12);color:var(--pri)}
.btn--dark{background:var(--pri);color:var(--white)}
.btn--dark:hover{background:var(--pri-l);color:var(--white);transform:translateY(-2px)}

/* ============================================
   HERO — Cinematic
   ============================================ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding-top:calc(var(--hh) + 4rem);padding-bottom:5rem;overflow:hidden}
.hero__bg{position:absolute;inset:0;background:linear-gradient(165deg,var(--pri-d),var(--pri) 40%,#163A6E);z-index:0}
.hero__grain{position:absolute;inset:-50%;width:200%;height:200%;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='.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");animation:grain 8s steps(10) infinite;pointer-events:none;opacity:.5}
.hero__gradient{position:absolute;inset:0;background:radial-gradient(circle at 20% 80%,rgba(37,99,235,.12),transparent 55%),radial-gradient(circle at 80% 20%,rgba(37,99,235,.08),transparent 55%);pointer-events:none}
.hero__inner{position:relative;z-index:2;width:100%}
.hero__content{max-width:680px}
.hero__eyebrow{display:inline-block;font-family:var(--font-ui);font-size:.72rem;font-weight:600;color:rgba(255,255,255,.55);letter-spacing:.2em;text-transform:uppercase;margin-bottom:1.2rem}
.hero__title{margin-bottom:1.5rem}
.hero__title-kr{display:block;font-family:var(--font-body);font-size:clamp(1rem,2vw,1.25rem);font-weight:400;color:rgba(255,255,255,.7);margin-bottom:.4rem;letter-spacing:.02em}
.hero__title-en{display:block;font-family:var(--font-display);font-size:clamp(2rem,5vw,3.6rem);font-weight:700;color:var(--white);line-height:1.15;letter-spacing:-.02em}
.hero__desc{font-size:clamp(.9rem,1.3vw,1.05rem);line-height:1.85;color:rgba(255,255,255,.6);margin-bottom:2rem;max-width:520px}
.hero__actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:3rem}
.hero__metrics{display:flex;gap:2.5rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.08)}
.metric{text-align:center}
.metric__num{display:block;font-family:var(--font-display);font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:700;color:var(--white);line-height:1}
.metric__suffix{font-family:var(--font-ui);font-size:clamp(1rem,2vw,1.3rem);font-weight:700;color:var(--acc-l)}
.metric__label{display:block;font-size:.75rem;color:rgba(255,255,255,.4);margin-top:.25rem;white-space:nowrap}
.hero__scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;color:rgba(255,255,255,.3);font-size:.65rem;letter-spacing:.15em;text-transform:uppercase}
.hero__scroll i{animation:float 2s ease-in-out infinite}

/* ============================================
   SECTION COMMON
   ============================================ */
.section{padding:6rem 0}
.section__head{text-align:center;margin-bottom:3.5rem}
.section__eyebrow{display:inline-block;font-family:var(--font-ui);font-size:.7rem;font-weight:600;color:var(--acc);letter-spacing:.14em;text-transform:uppercase;margin-bottom:.5rem}
.section__title{font-family:var(--font-display);font-size:clamp(1.6rem,3.5vw,2.6rem);font-weight:700;color:var(--g800);line-height:1.25;letter-spacing:-.02em}
.section__desc{font-size:1rem;color:var(--g400);margin-top:.75rem;line-height:1.75}

/* ============================================
   SERVICES — Swiper Slider
   ============================================ */
.services{background:var(--white);overflow:hidden}
.services__slider{padding-left:max(var(--pad),calc((100% - var(--max))/2 + var(--pad)))}
.services-swiper{overflow:visible;padding-bottom:2.5rem}
.services-swiper .swiper-slide{width:320px;height:auto}

.svc-slide{display:flex;flex-direction:column;height:100%;padding:2rem 1.8rem;background:var(--white);border:1px solid var(--g100);border-radius:var(--r-lg);transition:all .35s var(--ease);position:relative;overflow:hidden}
.svc-slide::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--acc),var(--acc-l));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.svc-slide:hover{border-color:transparent;box-shadow:var(--shadow-m);transform:translateY(-6px);color:inherit}
.svc-slide:hover::after{transform:scaleX(1)}

.svc-slide__num{font-family:var(--font-display);font-size:2.8rem;font-weight:700;color:var(--g50);line-height:1;margin-bottom:.5rem;transition:color .3s var(--ease)}
.svc-slide:hover .svc-slide__num{color:rgba(37,99,235,.08)}
.svc-slide__icon{width:48px;height:48px;display:grid;place-items:center;background:var(--g50);border-radius:var(--r-md);margin-bottom:1.2rem;transition:all .3s var(--ease)}
.svc-slide__icon i{font-size:1.2rem;color:var(--acc);transition:color .3s var(--ease)}
.svc-slide:hover .svc-slide__icon{background:var(--acc)}
.svc-slide:hover .svc-slide__icon i{color:var(--white)}
.svc-slide__title{font-family:var(--font-ui);font-size:1.15rem;font-weight:700;color:var(--g800);margin-bottom:.5rem}
.svc-slide__desc{font-size:.875rem;color:var(--g400);line-height:1.7;flex-grow:1}
.svc-slide__link{display:inline-flex;align-items:center;gap:.4rem;margin-top:1.2rem;font-size:.8rem;font-weight:600;color:var(--acc);transition:gap .3s var(--ease)}
.svc-slide:hover .svc-slide__link{gap:.7rem}

.services-pagination{text-align:center;margin-top:1rem}
.services-pagination .swiper-pagination-bullet{width:24px;height:3px;border-radius:3px;background:var(--g200);opacity:1;transition:all .3s var(--ease)}
.services-pagination .swiper-pagination-bullet-active{width:40px;background:var(--acc)}

/* ============================================
   DETAIL SECTIONS
   ============================================ */
.detail{background:var(--white)}
.detail--alt{background:var(--off)}
.detail__row{display:grid;grid-template-columns:1fr;gap:3rem;align-items:center}
.detail__text .section__eyebrow{margin-bottom:.4rem}
.detail__title{font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2.4rem);font-weight:700;color:var(--g800);letter-spacing:-.02em;margin-bottom:.4rem}
.detail__sub{font-size:1rem;font-weight:500;color:var(--g400);margin-bottom:1.2rem}
.detail__desc{font-size:.92rem;color:var(--g400);line-height:1.85;margin-bottom:1.5rem}
.detail__features{display:grid;gap:.6rem;margin-bottom:2rem}
.detail__features li{display:flex;align-items:center;gap:.75rem;font-size:.9rem;font-weight:500;color:var(--g600);padding:.5rem 0}
.detail__features li i{width:34px;height:34px;min-width:34px;display:grid;place-items:center;background:rgba(37,99,235,.07);border-radius:var(--r-sm);color:var(--acc);font-size:.85rem}

.detail__gallery{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.detail__img{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/3;background:var(--g50);border:1px solid var(--g100);transition:transform .5s var(--ease)}
.detail__img:hover{transform:scale(1.02)}
.detail__img img{width:100%;height:100%;object-fit:cover}
.img-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;gap:.6rem;color:var(--g300)}
.img-placeholder i{font-size:2rem}
.img-placeholder span{font-size:.75rem;font-weight:500}

/* ============================================
   WHY US — Swiper
   ============================================ */
.why{background:var(--off)}
.why-swiper{padding-bottom:2rem}
.why-swiper .swiper-slide{width:280px;height:auto}
.why__item{padding:2rem 1.6rem;background:var(--white);border:1px solid var(--g100);border-radius:var(--r-lg);height:100%;transition:all .35s var(--ease);position:relative}
.why__item:hover{border-color:transparent;box-shadow:var(--shadow-m);transform:translateY(-4px)}
.why__num{position:absolute;top:1rem;right:1.2rem;font-family:var(--font-display);font-size:2.2rem;font-weight:700;color:var(--g50);line-height:1}
.why__item > i{display:grid;place-items:center;width:44px;height:44px;background:rgba(37,99,235,.07);border-radius:var(--r-md);color:var(--acc);font-size:1.1rem;margin-bottom:1rem;transition:all .3s var(--ease)}
.why__item:hover > i{background:var(--acc);color:var(--white)}
.why__item h3{font-family:var(--font-ui);font-size:1.05rem;font-weight:700;color:var(--g800);margin-bottom:.4rem}
.why__item p{font-size:.85rem;color:var(--g400);line-height:1.7}

.why-scrollbar{height:3px!important;background:var(--g100)!important;border-radius:3px}
.why-scrollbar .swiper-scrollbar-drag{background:var(--acc)!important;border-radius:3px}

/* ============================================
   CTA
   ============================================ */
.cta{position:relative;padding:6rem 0;overflow:hidden}
.cta__bg{position:absolute;inset:0;background:linear-gradient(165deg,var(--pri-d),var(--pri) 50%,#163A6E);z-index:0}
.cta__inner{position:relative;z-index:2;text-align:center;max-width:600px;margin:0 auto}
.cta__title{font-family:var(--font-display);font-size:clamp(1.5rem,3.5vw,2.4rem);font-weight:700;color:var(--white);margin-bottom:1rem}
.cta__desc{font-size:.95rem;color:rgba(255,255,255,.6);line-height:1.8;margin-bottom:2rem}
.cta__note{margin-top:1.2rem;font-size:.8rem;color:rgba(255,255,255,.35)}

/* ============================================
   FOOTER
   ============================================ */
.footer{padding:3.5rem 0 0;background:var(--g800);color:var(--g300)}
.footer__top{display:grid;grid-template-columns:1fr;gap:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.06)}
.footer__brand p{font-size:.85rem;color:var(--g400);line-height:1.7;margin-top:.75rem}
.footer__cols{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.footer__col h4{font-family:var(--font-ui);font-size:.72rem;font-weight:600;color:var(--white);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.75rem}
.footer__col ul{display:flex;flex-direction:column;gap:.4rem}
.footer__col a{font-size:.84rem;color:var(--g400);transition:color .2s var(--ease)}
.footer__col a:hover{color:var(--white)}

.footer__bottom{padding:1.5rem 0;display:flex;flex-wrap:wrap;justify-content:center;gap:.2rem .5rem;font-size:.75rem;color:var(--g400);text-align:center}
.footer__bottom .sep{color:rgba(255,255,255,.12)}
.footer__bottom a{color:var(--g400)}
.footer__bottom a:hover{color:var(--white)}
.footer__bottom p{width:100%;margin-top:.4rem;font-size:.7rem;color:var(--g500)}

/* ============================================
   MOBILE STICKY CTA
   ============================================ */
.mobile-cta-bar{position:fixed;bottom:0;left:0;right:0;z-index:998;padding:.65rem 1rem;padding-bottom:calc(.65rem + env(safe-area-inset-bottom,0px));background:var(--white);border-top:1px solid var(--g100);box-shadow:0 -4px 20px rgba(0,0,0,.06);transform:translateY(100%);transition:transform .3s var(--ease)}
.mobile-cta-bar.is-visible{transform:translateY(0)}
.mobile-cta-bar a{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.8rem;background:var(--pri);color:var(--white);font-weight:700;border-radius:var(--r-md);font-size:.95rem}
.mobile-cta-bar a:hover{background:var(--pri-l);color:var(--white)}

/* ============================================
   SUBPAGE COMMON STYLES
   ============================================ */
.page-hero{padding:calc(var(--hh) + 4rem) 0 3rem;background:linear-gradient(165deg,var(--pri-d),var(--pri));position:relative;overflow:hidden}
.page-hero::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 70%,rgba(37,99,235,.1),transparent 60%);pointer-events:none}
.page-hero__inner{position:relative;z-index:2;text-align:center}
.page-hero__eyebrow{display:inline-block;font-family:var(--font-ui);font-size:.7rem;font-weight:600;color:rgba(255,255,255,.5);letter-spacing:.18em;text-transform:uppercase;margin-bottom:.75rem}
.page-hero__title{font-family:var(--font-display);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:700;color:var(--white);line-height:1.2;margin-bottom:.75rem}
.page-hero__desc{font-size:.95rem;color:rgba(255,255,255,.55);max-width:520px;margin:0 auto;line-height:1.7}

/* FAQ Accordion */
.faq-list{max-width:780px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--g100)}
.faq-item:first-child{border-top:1px solid var(--g100)}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:1rem;width:100%;padding:1.4rem 0;background:none;border:none;cursor:pointer;font-family:var(--font-body);font-size:1rem;font-weight:600;color:var(--g700);text-align:left;line-height:1.5;transition:color .2s var(--ease)}
.faq-q:hover{color:var(--acc)}
.faq-q i{flex-shrink:0;font-size:.75rem;color:var(--g300);transition:transform .3s var(--ease)}
.faq-item.is-open .faq-q i{transform:rotate(180deg);color:var(--acc)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease),padding .4s var(--ease)}
.faq-a__inner{padding:0 0 1.4rem;font-size:.9rem;color:var(--g400);line-height:1.8}

/* Portfolio Grid */
.portfolio-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
.portfolio-card{background:var(--white);border:1px solid var(--g100);border-radius:var(--r-lg);overflow:hidden;transition:all .35s var(--ease)}
.portfolio-card:hover{box-shadow:var(--shadow-m);transform:translateY(-4px)}
.portfolio-card__img{aspect-ratio:16/10;background:var(--g50);overflow:hidden}
.portfolio-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.portfolio-card:hover .portfolio-card__img img{transform:scale(1.05)}
.portfolio-card__body{padding:1.5rem}
.portfolio-card__tag{display:inline-block;font-size:.7rem;font-weight:600;color:var(--acc);letter-spacing:.06em;text-transform:uppercase;margin-bottom:.4rem}
.portfolio-card__title{font-family:var(--font-ui);font-size:1.05rem;font-weight:700;color:var(--g800);margin-bottom:.3rem}
.portfolio-card__desc{font-size:.84rem;color:var(--g400);line-height:1.65}

/* About Page */
.about-section{padding:4rem 0}
.about-section--alt{background:var(--off)}
.about-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;align-items:center}
.about-content h2{font-family:var(--font-display);font-size:clamp(1.4rem,3vw,2rem);font-weight:700;color:var(--g800);margin-bottom:1rem}
.about-content p{font-size:.92rem;color:var(--g400);line-height:1.85;margin-bottom:1rem}
.about-content p:last-child{margin-bottom:0}
.value-list{display:grid;gap:.75rem;margin-top:1.5rem}
.value-item{display:flex;gap:1rem;align-items:flex-start;padding:1.2rem;background:var(--white);border:1px solid var(--g100);border-radius:var(--r-md);transition:all .3s var(--ease)}
.value-item:hover{box-shadow:var(--shadow-s);border-color:transparent}
.value-item i{width:40px;height:40px;min-width:40px;display:grid;place-items:center;background:rgba(37,99,235,.07);border-radius:var(--r-sm);color:var(--acc);font-size:1rem}
.value-item h4{font-family:var(--font-ui);font-size:.95rem;font-weight:700;color:var(--g800);margin-bottom:.2rem}
.value-item p{font-size:.84rem;color:var(--g400);line-height:1.65;margin:0}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(min-width:768px){
  :root{--pad:2rem;--hh:72px}
  .detail__row{grid-template-columns:1fr 1fr;gap:4rem}
  .detail__row--reverse{direction:rtl}
  .detail__row--reverse > *{direction:ltr}
  .detail__features{grid-template-columns:1fr 1fr}
  .footer__top{grid-template-columns:1fr 2fr}
  .footer__cols{grid-template-columns:repeat(3,1fr)}
  .about-grid{grid-template-columns:1fr 1fr;gap:4rem}
  .portfolio-grid{grid-template-columns:repeat(2,1fr)}
}

@media(min-width:1024px){
  :root{--hh:76px}
  .main-nav{display:block}
  .header-cta{display:inline-flex}
  .mobile-menu-btn{display:none}
  .mobile-cta-bar{display:none}
  .hero{padding-top:calc(var(--hh) + 6rem)}
  .section{padding:7rem 0}
  .portfolio-grid{grid-template-columns:repeat(3,1fr)}
}

@media(min-width:1280px){:root{--max:1280px}}

/* Accessibility */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
  [data-animate]{opacity:1;transform:none}
}
:focus-visible{outline:2px solid var(--acc);outline-offset:2px;border-radius:4px}
::selection{background:rgba(37,99,235,.12);color:var(--g800)}
