/* ============================================================
   올인스토어 — 매장 인프라 통합 서비스 / 디자인 시스템
   ============================================================ */
:root{
  --navy-900:#071A33;
  --navy-800:#0A2540;
  --navy-700:#0E2A4D;
  --navy-600:#13396B;
  --blue-600:#2563EB;
  --blue-500:#3B82F6;
  --blue-100:#E5EEFC;
  --accent:#FB7A1E;        /* CTA 오렌지 */
  --accent-600:#EA6A0C;
  --accent-soft:#FFF1E6;
  --ink:#0F1B2D;
  --ink-2:#3D4B60;
  --muted:#5C6878;          /* 연한 배경 위 보조 텍스트 AA 확보 */
  --accent-text:#B5510A;    /* 흰 배경 위 오렌지 텍스트(AA 통과) */
  --line:#E6EBF1;
  --bg:#FFFFFF;
  --bg-soft:#F5F8FC;
  --bg-soft-2:#EFF4FA;
  --kakao:#FAE100;
  --kakao-ink:#3C1E1E;
  --ok:#16A34A;
  --radius:16px;
  --radius-lg:22px;
  --shadow-sm:0 1px 2px rgba(10,37,64,.06);
  --shadow:0 10px 30px -12px rgba(10,37,64,.18);
  --shadow-lg:0 28px 60px -24px rgba(10,37,64,.32);
  --container:1160px;
  --font:'Pretendard Variable',Pretendard,-apple-system,BlinkMacSystemFont,system-ui,'Apple SD Gothic Neo','Malgun Gothic',sans-serif;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:72px;-webkit-text-size-adjust:100%;}
body{
  margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);
  line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  letter-spacing:-.01em;overflow-x:clip;
}
html{overflow-x:clip;}
img,svg{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:0;background:none;}
h1,h2,h3,h4,h5{margin:0;line-height:1.22;letter-spacing:-.025em;font-weight:800;}
p{margin:0;}
ul,ol{margin:0;padding:0;list-style:none;}
[hidden]{display:none !important;}

/* ---------- 키보드 포커스 표시(접근성) ---------- */
a:focus-visible,button:focus-visible,summary:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,.form-tab:focus-visible{outline:3px solid var(--blue-500);outline-offset:2px;border-radius:8px;}
.checks label:focus-within,.agree:focus-within{outline:3px solid var(--blue-500);outline-offset:2px;}
.btn-accent:focus-visible{outline-color:var(--navy-900);}
.why a:focus-visible,.process a:focus-visible,.contact a:focus-visible,.cases a:focus-visible,.final-cta a:focus-visible,.contact .form-tab:focus-visible{outline-color:#9DC2FF;}

.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 22px;}
.container.narrow{max-width:840px;}
.section{padding:96px 0;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-weight:700;font-size:15px;border-radius:12px;padding:12px 20px;
  transition:transform .15s ease,box-shadow .2s ease,background .2s ease,color .2s ease;
  white-space:nowrap;cursor:pointer;line-height:1;
}
.btn svg{flex-shrink:0;}
.btn:active{transform:translateY(1px);}
.btn-sm{padding:9px 15px;font-size:14px;border-radius:10px;}
.btn-lg{padding:16px 28px;font-size:16.5px;border-radius:14px;}
.btn-block{display:flex;width:100%;}
.btn-accent{position:relative;overflow:hidden;background:var(--accent);color:var(--navy-900);box-shadow:0 10px 22px -10px rgba(251,122,30,.7);}
.btn-accent:hover{background:var(--accent-600);box-shadow:0 14px 28px -10px rgba(251,122,30,.8);transform:translateY(-2px);}
.btn-outline{background:rgba(255,255,255,.06);color:#fff;border:1.5px solid rgba(255,255,255,.45);backdrop-filter:blur(4px);}
.btn-outline:hover{background:rgba(255,255,255,.16);border-color:#fff;}
.btn-outline-light{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.55);}
.btn-outline-light:hover{background:rgba(255,255,255,.12);}
.btn-ghost{background:var(--bg-soft);color:var(--ink);border:1px solid var(--line);}
.btn-ghost:hover{background:var(--bg-soft-2);}
.btn-soft{background:var(--blue-100);color:var(--blue-600);}
.btn-soft:hover{background:#d7e6fc;}
.btn-dark{background:var(--navy-800);color:#fff;}
.btn-dark:hover{background:var(--navy-700);}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:60;background:rgba(255,255,255,.82);
  backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid var(--line);
}
.header-inner{display:flex;align-items:center;gap:18px;height:68px;}
.brand{display:inline-flex;align-items:center;gap:9px;font-size:20px;font-weight:800;letter-spacing:-.03em;color:var(--navy-800);}
.brand-mark{
  display:grid;place-items:center;width:34px;height:34px;border-radius:10px;
  background:linear-gradient(135deg,var(--blue-600),var(--navy-800));color:#fff;
  box-shadow:0 6px 14px -6px rgba(37,99,235,.7);
}
.brand-text strong{color:var(--blue-600);}
.site-header .brand-text strong{color:var(--accent);font-size:1.5em;line-height:1;letter-spacing:-.01em;display:inline-block;transform:skewX(13deg);position:relative;top:-8px;} /* 헤더 브랜드 'go' 공통: 오렌지+크게+위로. 기본은 왼쪽 기울임(짐싸go) */
.site-header .brand-text strong:first-of-type{transform:skewX(-13deg);} /* 첫 번째 go(장사go)는 오른쪽 기울임 */
.main-nav{display:flex;align-items:center;gap:6px;margin-left:14px;}
.main-nav a{padding:9px 13px;font-size:15px;font-weight:600;color:var(--ink-2);border-radius:9px;transition:.18s;}
.main-nav a:hover{color:var(--blue-600);background:var(--bg-soft);}
.header-cta{display:flex;align-items:center;gap:8px;margin-left:auto;}
.header-phone{font-weight:700;}
.nav-toggle{display:none;flex-direction:column;gap:5px;width:44px;height:44px;border-radius:10px;align-items:center;justify-content:center;margin-left:auto;}
.nav-toggle span{width:21px;height:2px;background:var(--navy-800);border-radius:2px;transition:.25s;}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle.open span:nth-child(2){opacity:0;}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.mobile-drawer{display:flex;flex-direction:column;padding:8px 22px 22px;gap:2px;border-bottom:1px solid var(--line);background:#fff;}
.mobile-drawer[hidden]{display:none;}
.mobile-drawer a{padding:13px 8px;font-weight:600;font-size:16px;border-bottom:1px solid var(--bg-soft-2);color:var(--ink-2);}
.mobile-drawer .drawer-cta{margin-top:12px;background:var(--accent);color:var(--navy-900);border-radius:12px;text-align:center;justify-content:center;border:0;font-weight:700;}

/* ---------- Eyebrow / titles ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:700;
  letter-spacing:.01em;color:#fff;background:rgba(255,255,255,.12);
  padding:6px 13px;border-radius:999px;border:1px solid rgba(255,255,255,.18);
}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(251,122,30,.25);}
.eyebrow.dark{color:var(--blue-600);background:var(--blue-100);border-color:transparent;}
.center-eyebrow{margin:0 auto;}
.section-title{font-size:clamp(27px,3.6vw,42px);letter-spacing:-.035em;color:var(--ink);}
.section-title.light{color:#fff;}
.section-lead{margin-top:16px;font-size:clamp(16px,1.5vw,18px);color:var(--muted);line-height:1.7;}
.section-head.center{text-align:center;max-width:720px;margin:0 auto 56px;}
.section-head.center .section-lead{margin-left:auto;margin-right:auto;}
.section-head .eyebrow{margin-bottom:16px;}

/* ---------- Hero ---------- */
.hero{position:relative;background:linear-gradient(168deg,var(--navy-800) 0%,var(--navy-900) 56%,#04101F 100%);color:#fff;overflow:hidden;padding-bottom:0;}
.hero-bg{position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(720px 420px at 78% 8%,rgba(37,99,235,.42),transparent 60%),
    radial-gradient(560px 420px at 6% 90%,rgba(251,122,30,.20),transparent 60%),
    radial-gradient(900px 600px at 120% 120%,rgba(59,130,246,.18),transparent 60%);
}
.hero-bg::after{content:"";position:absolute;inset:0;opacity:.4;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:46px 46px;mask-image:radial-gradient(720px 480px at 70% 20%,#000,transparent 75%);}
.hero-inner{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;padding:78px 22px 96px;}
.hero-copy h1{font-size:clamp(34px,5.2vw,60px);line-height:1.08;font-weight:850;letter-spacing:-.04em;margin:20px 0 0;}
.hero-copy .grad{background:linear-gradient(100deg,#fff 10%,#9DC2FF 50%,#FFB877 75%,#fff 100%);background-size:220% auto;-webkit-background-clip:text;background-clip:text;color:transparent;animation:grad-shimmer 7s ease-in-out infinite;}
.hero-sub{margin-top:22px;font-size:clamp(16px,1.7vw,18.5px);color:rgba(226,236,250,.82);max-width:540px;line-height:1.72;}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px;}
.hero-trust{display:flex;flex-wrap:wrap;gap:18px 24px;margin-top:30px;}
.hero-trust li{display:inline-flex;align-items:center;gap:8px;font-size:14.5px;font-weight:600;color:rgba(220,232,248,.9);}
.hero-trust svg{color:var(--blue-500);}

/* hero visual */
.hero-visual{position:relative;}
.store-card{position:relative;background:linear-gradient(160deg,rgba(20,49,92,.9),rgba(10,28,54,.92));border:1px solid rgba(99,148,221,.28);border-radius:24px;padding:20px;box-shadow:var(--shadow-lg);backdrop-filter:blur(6px);}
.store-card-glow{position:absolute;inset:-1px;border-radius:24px;background:linear-gradient(120deg,rgba(37,99,235,.5),transparent 40%,rgba(251,122,30,.35));opacity:.5;filter:blur(20px);z-index:-1;}
.store-top{display:flex;justify-content:space-between;margin-bottom:14px;}
.store-badge{font-size:12.5px;font-weight:700;color:#cfe0fb;background:rgba(59,130,246,.16);border:1px solid rgba(99,148,221,.3);padding:5px 11px;border-radius:999px;display:inline-flex;align-items:center;gap:7px;}
.store-badge.live{color:#fff;}
.pulse{width:8px;height:8px;border-radius:50%;background:#34D399;box-shadow:0 0 0 0 rgba(52,211,153,.6);animation:pulse 1.8s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(52,211,153,.55);}70%{box-shadow:0 0 0 9px rgba(52,211,153,0);}100%{box-shadow:0 0 0 0 rgba(52,211,153,0);}}
.storefront{width:100%;height:auto;border-radius:14px;background:radial-gradient(120% 120% at 50% 0%,rgba(37,99,235,.16),transparent 60%);}
.store-tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:16px;}
.store-tags span{font-size:12.5px;font-weight:600;color:#bcd2f5;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);padding:5px 10px;border-radius:8px;}
.float-chip{position:absolute;display:inline-flex;align-items:center;gap:9px;background:#fff;color:var(--ink);font-size:13.5px;font-weight:700;padding:10px 14px;border-radius:13px;box-shadow:var(--shadow-lg);}
.chip-ic{display:grid;place-items:center;width:24px;height:24px;border-radius:7px;color:#fff;flex-shrink:0;}
.chip-ic.ok{background:var(--ok);}
.chip-ic.call{background:var(--accent);}
.chip-a{top:-18px;left:-22px;animation:floaty 5s ease-in-out infinite;}
.chip-b{bottom:-40px;right:-14px;animation:floaty 5.5s ease-in-out infinite reverse;}
@keyframes floaty{0%,100%{transform:translateY(0);}50%{transform:translateY(-10px);}}

/* logo strip */
.logo-strip{position:relative;border-top:1px solid rgba(255,255,255,.08);background:rgba(4,16,31,.5);}
.strip-inner{display:flex;align-items:center;gap:18px;padding:18px 22px;overflow:hidden;}
.strip-label{font-size:12.5px;font-weight:700;color:rgba(157,194,255,.85);white-space:nowrap;letter-spacing:.02em;}
.strip-items{display:flex;align-items:center;gap:14px;flex-wrap:wrap;flex:1;min-width:0;color:rgba(226,236,250,.7);font-weight:600;font-size:14.5px;}
.strip-items i{width:4px;height:4px;border-radius:50%;background:rgba(157,194,255,.4);}

/* ---------- Problem ---------- */
.problem{background:var(--bg);}
.problem-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:center;}
.problem-copy .section-lead.strong{margin-top:18px;color:var(--ink-2);}
.problem-copy .section-lead.strong b{color:var(--blue-600);}
.pain-list{display:flex;flex-direction:column;gap:12px;}
.pain-list li{display:flex;align-items:flex-start;gap:13px;background:var(--bg-soft);border:1px solid var(--line);border-radius:13px;padding:16px 18px;font-weight:600;color:var(--ink-2);font-size:15.5px;}
.pain-list .x{flex-shrink:0;display:grid;place-items:center;width:22px;height:22px;border-radius:50%;background:#FEE2E2;color:#DC2626;font-size:12px;font-weight:800;margin-top:1px;}

/* ---------- Services ---------- */
.services{background:linear-gradient(180deg,var(--bg-soft) 0%,#fff 100%);}
.service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.service-card{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:26px 24px 24px;box-shadow:var(--shadow-sm);transition:transform .22s ease,box-shadow .22s ease,border-color .22s;overflow:hidden;}
.service-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--blue-500);opacity:.9;}
.service-card[data-accent="open"]::before{background:linear-gradient(90deg,#3B82F6,#2563EB);}
.service-card[data-accent="ops"]::before{background:linear-gradient(90deg,#22C55E,#16A34A);}
.service-card[data-accent="move"]::before{background:linear-gradient(90deg,#8B5CF6,#6D28D9);}
.service-card[data-accent="close"]::before{background:linear-gradient(90deg,#FB7A1E,#EA6A0C);}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent;}
.service-card.featured{border-color:rgba(251,122,30,.4);box-shadow:0 18px 44px -22px rgba(251,122,30,.5);}
.sc-flag{position:absolute;top:16px;right:16px;font-size:11px;font-weight:800;letter-spacing:.05em;color:var(--navy-900);background:var(--accent);padding:4px 9px;border-radius:999px;}
.sc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.sc-step{font-size:14px;font-weight:800;color:var(--muted);letter-spacing:.04em;}
.sc-ic{display:grid;place-items:center;width:52px;height:52px;border-radius:14px;background:var(--bg-soft);color:var(--blue-600);}
.service-card[data-accent="ops"] .sc-ic{color:#16A34A;}
.service-card[data-accent="move"] .sc-ic{color:#6D28D9;}
.service-card[data-accent="close"] .sc-ic{color:var(--accent-600);background:var(--accent-soft);}
.service-card h3{font-size:21px;margin-bottom:8px;}
.sc-desc{color:var(--muted);font-size:14.5px;line-height:1.6;min-height:46px;}
.sc-list{margin:16px 0 18px;display:flex;flex-direction:column;gap:9px;flex:1;}
.sc-list li{position:relative;padding-left:20px;font-size:14px;color:var(--ink-2);font-weight:500;}
.sc-list li::before{content:"";position:absolute;left:0;top:8px;width:7px;height:7px;border-radius:2px;background:var(--blue-500);}
.service-card[data-accent="close"] .sc-list li::before{background:var(--accent);}
.sc-link{font-weight:700;font-size:14.5px;color:var(--blue-600);}
.service-card[data-accent="close"] .sc-link{color:var(--accent-text);}
.sc-link:hover{text-decoration:underline;}

/* ---------- Why (dark) ---------- */
.why{background:linear-gradient(165deg,var(--navy-800),var(--navy-900));color:#fff;}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.why-item{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:var(--radius);padding:26px 24px;transition:.22s;}
.why-item:hover{background:rgba(255,255,255,.07);transform:translateY(-4px);}
.why-ic{display:grid;place-items:center;width:50px;height:50px;border-radius:13px;background:rgba(59,130,246,.16);color:var(--blue-500);margin-bottom:16px;}
.why-item h3{font-size:18px;margin-bottom:8px;}
.why-item p{color:rgba(208,222,242,.72);font-size:14.5px;line-height:1.62;}

/* ---------- Packages ---------- */
.packages{background:var(--bg-soft);}
.package-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;align-items:stretch;}
.pkg{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px 24px;box-shadow:var(--shadow-sm);transition:.22s;}
.pkg:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);}
.pkg.featured{border:2px solid var(--accent);box-shadow:0 22px 50px -24px rgba(251,122,30,.55);}
.pkg-best{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--accent);color:var(--navy-900);font-size:12px;font-weight:800;padding:5px 14px;border-radius:999px;white-space:nowrap;box-shadow:0 8px 18px -8px rgba(251,122,30,.8);}
.pkg-head h3{font-size:21px;}
.pkg-head p{margin-top:6px;color:var(--muted);font-size:13.5px;min-height:38px;}
.pkg-list{margin:18px 0 22px;display:flex;flex-direction:column;gap:11px;flex:1;}
.pkg-list li{position:relative;padding-left:25px;font-size:14.5px;color:var(--ink-2);font-weight:500;}
.pkg-list li::before{content:"";position:absolute;left:0;top:3px;width:16px;height:16px;border-radius:50%;background:var(--blue-100) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%232563EB' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E") center/11px no-repeat;}
.pkg-close{background:linear-gradient(180deg,#fff,#fbf4ee);border-color:#f3dcc8;}
.pkg-close .pkg-list li::before{background:var(--accent-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%23EA6A0C' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E") center/11px no-repeat;}

/* ---------- Process ---------- */
.process{background:linear-gradient(165deg,var(--navy-900),#04101F);color:#fff;}
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;counter-reset:s;position:relative;}
.steps::before{content:"";position:absolute;top:24px;left:10%;right:10%;height:2px;background:linear-gradient(90deg,transparent,rgba(59,130,246,.5),transparent);}
.step{position:relative;text-align:center;padding:0 8px;}
.step-num{position:relative;z-index:1;display:grid;place-items:center;width:50px;height:50px;margin:0 auto 16px;border-radius:50%;background:linear-gradient(135deg,var(--blue-600),var(--navy-700));color:#fff;font-weight:800;font-size:19px;box-shadow:0 0 0 6px rgba(37,99,235,.14);}
.step h3{font-size:16.5px;margin-bottom:7px;}
.step p{color:rgba(208,222,242,.66);font-size:13.5px;line-height:1.55;}

/* ---------- Industries ---------- */
.industries{background:#fff;}
.chip-marquee{display:flex;flex-direction:column;gap:14px;}
.chip-row span{display:inline-block;font-size:15.5px;font-weight:600;color:var(--ink-2);background:var(--bg-soft);border:1px solid var(--line);padding:11px 20px;border-radius:999px;white-space:nowrap;flex:none;transition:.18s;}
.chip-row span:hover{background:var(--blue-100);color:var(--blue-600);border-color:transparent;}

/* ---------- Cases ---------- */
.cases{background:linear-gradient(180deg,var(--navy-900),#061226);color:#fff;}
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:940px;margin:0 auto;}
.case{position:relative;aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;margin:0;border:1px solid rgba(255,255,255,.1);display:flex;align-items:flex-end;}
.case::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(4,16,31,.85));}
.case figcaption{position:relative;z-index:1;padding:18px;display:flex;flex-direction:column;gap:3px;}
.case figcaption b{font-size:16px;}
.case figcaption span{font-size:13px;color:rgba(208,222,242,.75);}
.ph-1{background:linear-gradient(135deg,#1E3A8A,#2563EB);}
.ph-2{background:linear-gradient(135deg,#0E7490,#0891B2);}
.ph-3{background:linear-gradient(135deg,#6D28D9,#8B5CF6);}
.ph-4{background:linear-gradient(135deg,#0F766E,#14B8A6);}
.ph-5{background:linear-gradient(135deg,#B45309,#F59E0B);}
.ph-6{background:linear-gradient(135deg,#9A3412,#EA580C);}

/* ---------- 설치사례 카드뉴스 ---------- */
.case-news{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1000px;margin:0 auto;}
.cnews-card{display:flex;flex-direction:column;text-align:left;padding:0;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;color:#fff;transition:transform .2s ease,box-shadow .2s ease,border-color .2s;}
.cnews-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:rgba(99,148,221,.45);}
.cnews-media{position:relative;display:block;aspect-ratio:16/10;background:#0b1f3f;overflow:hidden;}
.cnews-media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease;}
.cnews-card:hover .cnews-media img{transform:scale(1.05);}
.cnews-media.noimg{display:grid;place-items:center;font-size:38px;color:rgba(157,194,255,.45);}
.cnews-count{position:absolute;top:10px;right:10px;font-size:12px;font-weight:700;color:#fff;background:rgba(4,16,31,.7);padding:4px 9px;border-radius:999px;backdrop-filter:blur(4px);}
.cnews-body{display:flex;flex-direction:column;gap:6px;padding:16px 18px 18px;}
.cnews-title{font-size:16.5px;font-weight:800;color:#fff;line-height:1.35;letter-spacing:-.01em;}
.cnews-excerpt{font-size:13.5px;color:rgba(208,222,242,.72);line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}

/* 설치사례 상세 모달(카드뉴스 뷰어) */
.case-modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;}
.cm-backdrop{position:absolute;inset:0;background:rgba(4,12,24,.78);backdrop-filter:blur(4px);}
.cm-box{position:relative;z-index:1;width:100%;max-width:620px;max-height:90vh;display:flex;flex-direction:column;background:#0c1f3c;border:1px solid rgba(99,148,221,.3);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);}
.cm-close{position:absolute;top:10px;right:10px;z-index:3;width:38px;height:38px;border-radius:50%;background:rgba(4,16,31,.6);color:#fff;font-size:18px;display:grid;place-items:center;backdrop-filter:blur(4px);}
.cm-close:hover{background:rgba(4,16,31,.85);}
.cm-slider{position:relative;background:#081728;flex:none;}
.cm-viewport{overflow:hidden;}
.cm-track{display:flex;transition:transform .4s cubic-bezier(.4,.1,.2,1);}
.cm-slide{flex:0 0 100%;aspect-ratio:16/10;background:#081728;}
.cm-slide img{width:100%;height:100%;object-fit:contain;display:block;}
.cm-arrow{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.92);color:var(--navy-800);display:grid;place-items:center;box-shadow:var(--shadow);z-index:2;cursor:pointer;transition:background .15s,transform .15s;}
.cm-arrow:hover{background:#fff;transform:translateY(-50%) scale(1.08);}
.cm-prev{left:12px;} .cm-next{right:12px;}
.cm-dots{position:absolute;left:0;right:0;bottom:10px;display:flex;justify-content:center;gap:7px;z-index:2;}
.cm-dot{width:8px;height:8px;padding:0;border:0;border-radius:50%;background:rgba(255,255,255,.4);cursor:pointer;transition:.25s;}
.cm-dot.active{background:var(--accent);width:22px;border-radius:4px;}
.cm-text{padding:20px 22px 24px;overflow-y:auto;}
.cm-title{font-size:19px;font-weight:800;color:#fff;letter-spacing:-.02em;margin-bottom:10px;}
.cm-body{font-size:14.5px;color:rgba(214,226,244,.82);line-height:1.7;white-space:pre-wrap;}
@media (max-width:880px){.case-news{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.case-news{grid-template-columns:1fr;}.cm-text{padding:16px 18px 20px;}}

/* 설치사례 전용 페이지(/cases) + 홈 미리보기 더보기 */
.cases-page{background:linear-gradient(180deg,var(--navy-900),#061226);color:#fff;min-height:62vh;}
.cases-back{display:inline-block;margin-top:18px;color:rgba(157,194,255,.92);font-weight:600;font-size:14.5px;}
.cases-back:hover{color:#fff;}
.cases-empty{text-align:center;color:rgba(208,222,242,.8);padding:24px 0 10px;}
.cases-empty p{font-size:16px;line-height:1.7;margin-bottom:22px;}
.cases-more{text-align:center;margin-top:34px;}

/* ---------- FAQ ---------- */
.faq{background:var(--bg-soft);}
.faq-list{display:flex;flex-direction:column;gap:12px;}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:box-shadow .2s,border-color .2s;}
.faq-item[open]{border-color:rgba(37,99,235,.35);box-shadow:var(--shadow);}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 22px;font-weight:700;font-size:16.5px;color:var(--ink);}
.faq-item summary::-webkit-details-marker{display:none;}
.chev{position:relative;flex-shrink:0;width:18px;height:18px;}
.chev::before,.chev::after{content:"";position:absolute;top:50%;width:10px;height:2px;background:var(--blue-600);border-radius:2px;transition:.25s;}
.chev::before{left:0;transform:rotate(45deg);}
.chev::after{right:0;transform:rotate(-45deg);}
.faq-item[open] .chev::before{transform:rotate(-45deg);}
.faq-item[open] .chev::after{transform:rotate(45deg);}
.faq-a{padding:0 22px 22px;color:var(--ink-2);font-size:15px;line-height:1.72;}

/* ---------- 가맹 신청 준비 서류 ---------- */
.docs{background:var(--bg);}
.docs-required{position:relative;background:linear-gradient(180deg,#fff,var(--bg-soft));border:1px solid var(--blue-100);border-radius:var(--radius-lg);padding:30px 30px 28px;box-shadow:var(--shadow-sm);overflow:hidden;}
.docs-required::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3B82F6,#2563EB);}
.dr-head{display:flex;flex-direction:column;gap:6px;margin-bottom:22px;}
.docs-tag{align-self:flex-start;font-size:12.5px;font-weight:800;letter-spacing:.02em;padding:5px 12px;border-radius:999px;background:var(--blue-100);color:var(--blue-600);}
.dr-head h3{font-size:clamp(20px,2.2vw,24px);color:var(--ink);}
.dr-sub{color:var(--muted);font-size:14.5px;line-height:1.6;}
.dr-list{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;}
.dr-list li{position:relative;display:flex;flex-direction:column;gap:3px;padding:16px 16px 16px 40px;background:#fff;border:1px solid var(--line);border-radius:14px;}
.dr-list li::before{content:"";position:absolute;left:14px;top:17px;width:18px;height:18px;border-radius:50%;background:var(--blue-100) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%232563EB' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E") center/11px no-repeat;}
.dr-list li b{font-size:14.5px;color:var(--ink);font-weight:700;letter-spacing:-.01em;}
.dr-list li small{font-size:12.5px;color:var(--muted);line-height:1.5;}
.docs-sub-title{font-size:18px;color:var(--ink-2);margin:40px 0 18px;text-align:center;}
.docs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch;}
.docs-card{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:26px 24px 24px;box-shadow:var(--shadow-sm);overflow:hidden;transition:transform .22s ease,box-shadow .22s ease,border-color .22s;}
.docs-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;}
.docs-card[data-cat="food"]::before{background:linear-gradient(90deg,#FB7A1E,#EA6A0C);}
.docs-card[data-cat="corp"]::before{background:linear-gradient(90deg,#3B82F6,#2563EB);}
.docs-card[data-cat="foreign"]::before{background:linear-gradient(90deg,#8B5CF6,#6D28D9);}
.docs-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent;}
.dc-top{display:flex;flex-direction:column;gap:12px;margin-bottom:14px;}
.dc-ic{display:grid;place-items:center;width:52px;height:52px;border-radius:14px;background:var(--bg-soft);color:var(--blue-600);}
.docs-card[data-cat="food"] .dc-ic{background:var(--accent-soft);color:var(--accent-600);}
.docs-card[data-cat="foreign"] .dc-ic{color:#6D28D9;}
.docs-when{align-self:flex-start;font-size:12.5px;font-weight:700;color:var(--muted);background:var(--bg-soft);border:1px solid var(--line);padding:4px 11px;border-radius:999px;}
.docs-card h4{font-size:18px;color:var(--ink);margin-bottom:14px;}
.docs-list{display:flex;flex-direction:column;gap:11px;flex:1;}
.docs-list li{position:relative;padding-left:25px;}
.docs-list li::before{content:"";position:absolute;left:0;top:4px;width:16px;height:16px;border-radius:50%;background:var(--blue-100) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%232563EB' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E") center/11px no-repeat;}
.docs-card[data-cat="food"] .docs-list li::before{background:var(--accent-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%23EA6A0C' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E") center/11px no-repeat;}
.docs-list li b{display:block;font-size:14.5px;color:var(--ink);font-weight:700;}
.docs-list li small{display:block;margin-top:2px;font-size:12.5px;color:var(--muted);line-height:1.5;}
.docs-note{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-top:34px;background:var(--accent-soft);border-left:4px solid var(--accent);border-radius:14px;padding:20px 24px;}
.docs-note p{flex:1;min-width:240px;font-size:15px;color:var(--ink-2);font-weight:600;line-height:1.6;}
.docs-note p b{color:var(--accent-text);}
@media (max-width:1024px){.dr-list{grid-template-columns:repeat(3,1fr);}.docs-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:880px){.dr-list{grid-template-columns:repeat(2,1fr);}}
@media (max-width:680px){.dr-list{grid-template-columns:1fr;}.docs-grid{grid-template-columns:1fr;}.docs-required{padding:24px 18px;}.docs-note{flex-direction:column;align-items:flex-start;}.docs-note .btn{width:100%;}}

/* ---------- Contact ---------- */
.contact{background:linear-gradient(165deg,var(--navy-800),var(--navy-900));color:#fff;}
.contact-wrap{display:grid;grid-template-columns:.92fr 1.08fr;gap:44px;align-items:start;}
.contact-aside .eyebrow{margin-bottom:16px;}
.contact-lead{margin-top:18px;color:rgba(208,222,242,.78);font-size:16px;line-height:1.72;max-width:420px;}
.contact-direct{margin-top:30px;display:flex;flex-direction:column;gap:14px;}
.contact-direct li{display:flex;align-items:center;gap:14px;}
.cd-ic{display:grid;place-items:center;width:46px;height:46px;border-radius:12px;background:rgba(59,130,246,.16);color:var(--blue-500);flex-shrink:0;}
.cd-ic.kakao{background:var(--kakao);color:var(--kakao-ink);}
.contact-direct small{display:block;font-size:12.5px;color:rgba(157,194,255,.8);margin-bottom:2px;}
.contact-direct a,.contact-direct strong{font-size:18px;font-weight:800;color:#fff;}

/* form */
.contact-form-box{background:#fff;border-radius:22px;padding:10px;box-shadow:var(--shadow-lg);color:var(--ink);}
.form-tabs{display:flex;gap:6px;padding:8px;background:var(--bg-soft);border-radius:16px;margin:6px 6px 4px;}
.form-tab{flex:1;padding:12px;border-radius:11px;font-weight:700;font-size:15px;color:var(--muted);transition:.2s;}
.form-tab.active{background:#fff;color:var(--navy-800);box-shadow:var(--shadow-sm);}
.form-tab[data-tabbtn="closing"].active{color:var(--accent-text);}
.lead-form{padding:14px 18px 20px;display:flex;flex-direction:column;gap:14px;}
.form-row{display:grid;gap:14px;}
.form-row.two{grid-template-columns:1fr 1fr;}
.field{display:flex;flex-direction:column;gap:7px;}
.field>span,.field legend{font-size:13.5px;font-weight:700;color:var(--ink-2);}
.field i{color:var(--accent);font-style:normal;}
.field input,.field textarea{
  width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:11px;
  font-family:inherit;font-size:15px;color:var(--ink);background:#fff;transition:.16s;
}
.field input::placeholder,.field textarea::placeholder{color:#767F8C;}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--blue-500);box-shadow:0 0 0 4px rgba(59,130,246,.13);}
.field textarea{resize:vertical;min-height:84px;}
.check-group{border:0;padding:0;margin:0;}
.check-group legend{padding:0;margin-bottom:9px;}
.check-group legend small{font-weight:500;color:var(--muted);}
.checks{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;}
.checks label{display:flex;align-items:center;gap:8px;padding:11px 12px;border:1.5px solid var(--line);border-radius:11px;cursor:pointer;font-size:14px;font-weight:600;color:var(--ink-2);transition:.15s;}
.checks input{accent-color:var(--blue-600);width:16px;height:16px;flex-shrink:0;}
.checks label:has(input:checked){border-color:var(--blue-500);background:var(--blue-100);color:var(--blue-600);}
.agree{display:flex;align-items:flex-start;gap:9px;font-size:13.5px;color:var(--muted);cursor:pointer;}
.agree input{margin-top:2px;accent-color:var(--blue-600);width:16px;height:16px;flex-shrink:0;}
.form-status{text-align:center;font-weight:700;font-size:14.5px;min-height:8px;}
.form-status.ok{color:var(--ok);}
.form-status.err{color:#DC2626;}

/* 사진은 카카오톡으로 받기 (폼 내 파일 첨부 제거) */
.field>span small{font-weight:500;color:var(--muted);font-size:.84em;}
.photo-kakao{display:flex;align-items:center;gap:13px;border:1.5px solid var(--kakao);background:#FFFBE6;border-radius:11px;padding:13px 16px;cursor:pointer;transition:background .15s,border-color .15s,transform .12s;}
.photo-kakao:hover{background:#FFF6C2;transform:translateY(-1px);}
.photo-kakao .pk-ic{display:grid;place-items:center;width:36px;height:36px;border-radius:9px;background:var(--kakao);color:var(--kakao-ink);flex:none;}
.photo-kakao .pk-tx{font-size:14px;color:var(--ink-2);font-weight:600;line-height:1.5;}
.photo-kakao .pk-tx b{color:var(--ink);}
.photo-kakao .pk-tx small{display:block;font-weight:500;color:var(--muted);font-size:12.5px;margin-top:2px;}

/* ---------- flatpickr 날짜 달력 (데스크톱: 크게 + 브랜드) ---------- */
.flatpickr-calendar{width:370px!important;font-family:var(--font);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-lg);padding:8px 10px 12px;}
.flatpickr-calendar.arrowTop::before,.flatpickr-calendar.arrowTop::after{border-bottom-color:#fff;}
.flatpickr-calendar.arrowBottom::before,.flatpickr-calendar.arrowBottom::after{border-top-color:#fff;}
.flatpickr-months{margin-bottom:6px;}
.flatpickr-months .flatpickr-month{height:48px;}
.flatpickr-current-month{font-size:19px;font-weight:800;padding-top:10px;color:var(--ink);}
.flatpickr-current-month input.cur-year{font-size:19px;font-weight:800;}
.flatpickr-current-month .flatpickr-monthDropdown-months{font-size:19px;font-weight:800;}
.flatpickr-months .flatpickr-prev-month,.flatpickr-months .flatpickr-next-month{padding:12px 14px;}
.flatpickr-months .flatpickr-prev-month svg,.flatpickr-months .flatpickr-next-month svg{width:16px;height:16px;}
.flatpickr-months .flatpickr-prev-month:hover svg,.flatpickr-months .flatpickr-next-month:hover svg{fill:var(--blue-600);}
span.flatpickr-weekday{font-size:14px;font-weight:700;color:var(--muted);}
.flatpickr-days,.dayContainer,.flatpickr-weekdays,.flatpickr-rContainer,.flatpickr-weekdaycontainer{width:350px!important;min-width:350px!important;max-width:350px!important;}
.flatpickr-day{max-width:50px;height:48px;line-height:48px;font-size:15.5px;border-radius:11px;}
.flatpickr-day:hover,.flatpickr-day:focus{background:var(--blue-100);border-color:var(--blue-100);}
.flatpickr-day.today{border-color:var(--accent);color:var(--accent-text);font-weight:800;}
.flatpickr-day.today:hover{background:var(--accent);border-color:var(--accent);color:var(--navy-900);}
.flatpickr-day.selected,.flatpickr-day.selected:hover{background:var(--blue-600);border-color:var(--blue-600);color:#fff;font-weight:700;}
.flatpickr-day.flatpickr-disabled,.flatpickr-day.prevMonthDay,.flatpickr-day.nextMonthDay{color:#c7d0db;}
/* 모바일: 달력이 화면 폭을 넘지 않도록(가로 스크롤 방지) */
@media (max-width:420px){
  .flatpickr-calendar{width:calc(100vw - 28px)!important;}
  .flatpickr-days,.dayContainer,.flatpickr-weekdays,.flatpickr-rContainer,.flatpickr-weekdaycontainer{width:100%!important;min-width:0!important;max-width:100%!important;}
  .flatpickr-day{max-width:14.28%;}
}

/* ---------- Final CTA ---------- */
.final-cta{background:linear-gradient(120deg,var(--blue-600),var(--navy-800));color:#fff;text-align:center;padding:78px 0;position:relative;overflow:hidden;}
.final-cta::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 80% 0%,rgba(251,122,30,.25),transparent 60%);}
.final-inner{position:relative;}
.final-cta h2{font-size:clamp(26px,3.6vw,40px);letter-spacing:-.035em;}
.final-cta p{margin-top:14px;font-size:17px;color:rgba(226,236,250,.85);}
.final-actions{margin-top:30px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}

/* ---------- Footer ---------- */
.site-footer{background:#061226;color:rgba(208,222,242,.7);}
.footer-inner{display:grid;grid-template-columns:1.4fr 2fr;gap:40px;padding:56px 22px 40px;}
.footer-brand .brand{color:#fff;margin-bottom:16px;}
.footer-brand .brand-text strong{color:var(--blue-500);}
.footer-brand p{font-size:14px;line-height:1.7;max-width:340px;}
.footer-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.footer-cols .foot-h{color:#fff;font-size:14.5px;margin-bottom:14px;}
.footer-cols a,.foot-meta{display:block;font-size:14px;padding:5px 0;color:rgba(208,222,242,.68);transition:.15s;}
.footer-cols a:hover{color:#fff;}
.foot-meta{color:rgba(157,194,255,.7);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);}
.footer-bottom p{padding:18px 0;font-size:13px;color:rgba(157,177,206,.85);}
.footer-bottom .biz-info{line-height:1.85;}
.footer-bottom .copyr{display:inline-block;margin-top:8px;opacity:.75;}

/* ---------- Mobile sticky bar ---------- */
.mobile-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:70;background:#fff;border-top:1px solid var(--line);box-shadow:0 -6px 20px -8px rgba(10,37,64,.18);padding:8px 8px calc(8px + env(safe-area-inset-bottom));grid-template-columns:1fr 1fr 1.3fr;gap:8px;}
.mb-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:9px 4px;border-radius:12px;font-size:12px;font-weight:700;color:var(--ink-2);background:var(--bg-soft);}
.mb-item.kakao{background:var(--kakao);color:var(--kakao-ink);}
.mb-item.primary{background:var(--accent);color:var(--navy-900);}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}
/* ---------- 모션 (무한 롤링·쉬머·아이콘 호버·버튼 샤인) ---------- */
.mq-viewport{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);}
.mq-track{display:flex;align-items:center;width:max-content;flex:none;animation:mq-scroll var(--mq-dur,30s) linear infinite;will-change:transform;}
.mq-track.mq-rev{animation-direction:reverse;}
.mq-viewport:hover .mq-track{animation-play-state:paused;}
@keyframes mq-scroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.strip-items .mq-track>*{margin-right:14px;}
.chip-row .mq-track>*{margin-right:12px;}
@keyframes grad-shimmer{0%,100%{background-position:0 center;}50%{background-position:100% center;}}
.btn-accent::after{content:"";position:absolute;top:0;left:-75%;width:50%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.45),transparent);transform:skewX(-18deg);pointer-events:none;}
.btn-accent:hover::after{animation:btn-shine .75s ease;}
@keyframes btn-shine{to{left:125%;}}
.sc-ic,.dc-ic,.why-ic{transition:transform .3s cubic-bezier(.2,.7,.2,1);}
.service-card:hover .sc-ic,.docs-card:hover .dc-ic{transform:scale(1.1) rotate(-5deg);}
.why-item:hover .why-ic{transform:scale(1.12);}

@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}.reveal{opacity:1;transform:none;transition:none;}.float-chip,.pulse,.mq-track,.hero-copy .grad{animation:none!important;}.btn-accent::after{display:none;}}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:1024px){
  .service-grid,.package-grid{grid-template-columns:repeat(2,1fr);}
  .why-grid{grid-template-columns:repeat(2,1fr);}
  .steps{grid-template-columns:1fr;gap:18px;}
  .steps::before{display:none;}
  .step{display:grid;grid-template-columns:50px 1fr;gap:4px 16px;text-align:left;}
  .step-num{margin:0;grid-row:span 2;}
  .hero-inner{gap:40px;}
}
@media (max-width:880px){
  .main-nav,.header-phone{display:none;}
  .nav-toggle{display:flex;}
  .header-cta{margin-left:auto;}
  .header-cta .btn-sm{padding:13px 16px;}
  .mobile-bar{display:grid;}
  body{padding-bottom:calc(76px + env(safe-area-inset-bottom));}
  .hero-inner{grid-template-columns:1fr;padding:54px 22px 88px;}
  .hero-visual{max-width:440px;margin:8px auto 0;}
  .hero-trust{justify-content:flex-start;}
  .problem-grid{grid-template-columns:1fr;gap:34px;}
  .contact-wrap{grid-template-columns:1fr;gap:30px;}
  .case-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:680px){
  .section{padding:64px 0;}
  .section-head.center{margin-bottom:38px;}
  .service-grid,.package-grid,.why-grid{grid-template-columns:1fr;}
  .checks{grid-template-columns:repeat(2,1fr);}
  .form-row.two{grid-template-columns:1fr;}
  .footer-inner{grid-template-columns:1fr;gap:28px;}
  .footer-cols{grid-template-columns:repeat(3,1fr);}
  .case-grid{grid-template-columns:1fr;}
  .float-chip{font-size:12px;padding:8px 11px;}
  .chip-a{left:-8px;top:-14px;}
  .chip-b{right:-6px;}
  .final-actions .btn{width:100%;}
}
@media (max-width:420px){
  .footer-cols{grid-template-columns:1fr 1fr;}
  .hero-actions .btn{width:100%;}
}

/* ---------- 스킵 링크(키보드/스크린리더: 본문 바로가기) ---------- */
.skip-link{position:absolute;left:8px;top:-48px;z-index:100;background:#fff;color:var(--ink);padding:10px 16px;border-radius:8px;font-weight:700;box-shadow:var(--shadow);transition:top .15s;}
.skip-link:focus{top:8px;outline:3px solid var(--blue-500);outline-offset:2px;}
