/* ============================================================
   ふるや工務店 リニューアル案 — styles
   ブランド: ロイヤルブルー / 明朝見出し / 余白で職人感
   ============================================================ */
:root{
  --blue:#2020CC;
  --blue-bright:#3535E0;
  --navy:#15166b;
  --base:#F5F7FF;
  --sand:#f3efe8;
  --white:#FFFFFF;
  --ink:#1A1A1A;
  --ink-soft:#52525e;
  --line:#e4e7f5;
  --ph:#e0e0e0;
  --maxw:1180px;
  --serif:"Shippori Mincho B1", serif;
  --sans:"Noto Sans JP", system-ui, sans-serif;
  --shadow:0 10px 30px rgba(32,32,204,.08);
  --shadow-lg:0 24px 56px rgba(20,22,80,.16);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{font-family:var(--sans);color:var(--ink);background:var(--white);line-height:1.85;font-size:16px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;width:100%}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-family:var(--sans);font-weight:700;font-size:16px;padding:16px 30px;border-radius:8px;cursor:pointer;border:none;min-height:56px;line-height:1.3;text-align:center;transition:transform .2s,box-shadow .2s,background .2s}
.btn svg{flex-shrink:0}
.btn-primary{background:var(--navy);color:#fff;box-shadow:0 10px 22px rgba(21,22,107,.28)}
.btn-primary:hover{background:var(--blue-bright);transform:translateY(-2px);box-shadow:0 14px 28px rgba(32,32,204,.34)}
.btn-ghost{background:#fff;color:var(--navy);border:2px solid var(--navy)}
.btn-ghost:hover{background:var(--base);transform:translateY(-2px)}
.btn-lg{font-size:17px;padding:19px 38px;min-height:62px}
.btn-white{background:#fff;color:var(--navy)}
.btn-white:hover{background:var(--base);transform:translateY(-2px)}

/* ---------- Header ---------- */
header.site{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.head-inner{display:flex;align-items:center;gap:24px;height:80px}
.logo{display:flex;align-items:center;flex-shrink:0}
.logo-img{height:60px;width:auto;display:block}
nav.main{display:flex;gap:26px;margin-left:auto}
nav.main a{font-weight:700;font-size:15px;color:var(--ink);padding:6px 0;position:relative;white-space:nowrap}
nav.main a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--navy);transition:width .25s}
nav.main a:hover{color:var(--navy)}
nav.main a:hover::after{width:100%}
.head-cta{display:flex;align-items:center;gap:16px;flex-shrink:0}
.head-tel{text-align:center;line-height:1.2}
.head-tel small{display:block;font-size:10.5px;letter-spacing:.1em;color:var(--ink-soft);font-weight:700;text-align:center}
.head-tel b{font-family:var(--serif);font-size:23px;color:var(--navy);font-weight:800;letter-spacing:.02em}
.head-cta .btn{padding:12px 22px;min-height:46px;font-size:14px}
.hamburger{display:none;width:46px;height:46px;border:1px solid var(--line);border-radius:8px;background:#fff;cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px}
.hamburger span{width:22px;height:2px;background:var(--navy);transition:.25s}
.head-mtel{display:none;flex-direction:column;align-items:center;line-height:1.05;margin-left:auto}
.head-mtel small{font-size:9px;letter-spacing:.04em;color:var(--ink-soft);font-weight:700}
.head-mtel b{font-family:var(--serif);font-size:19px;color:var(--navy);font-weight:800}

/* ---------- Hero ---------- */
.hero{position:relative;background:#e9edfb url("exterior.jpg") center 30%/cover no-repeat;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(102deg,rgba(255,255,255,.96) 0%,rgba(255,255,255,.9) 42%,rgba(255,255,255,.66) 72%,rgba(240,243,255,.46) 100%)}
.hero-inner{position:relative;padding:92px 24px 60px;max-width:var(--maxw);margin:0 auto}
.hero-copy{max-width:680px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);padding:8px 16px;border-radius:100px;font-size:13px;font-weight:700;letter-spacing:.03em;margin-bottom:22px;color:var(--navy);box-shadow:var(--shadow)}
.hero h1{font-family:var(--serif);font-weight:800;font-size:clamp(33px,4.7vw,56px);line-height:1.28;letter-spacing:.01em;margin-bottom:18px;color:var(--navy)}
.hero .lead{font-size:clamp(16px,1.7vw,18.5px);line-height:1.85;color:var(--ink);max-width:560px;margin-bottom:14px;font-weight:500}
.hero .tag{font-family:var(--serif);font-size:15px;letter-spacing:.14em;color:var(--navy);margin-bottom:30px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero-tel{display:inline-flex;flex-direction:column;align-items:flex-start;gap:4px;margin-top:26px}
.hero-tel small{font-size:12px;color:var(--ink-soft);letter-spacing:.08em;font-weight:700}
.hero-tel .row{display:inline-flex;align-items:center;gap:10px;color:var(--navy)}
.hero-tel .row .num{font-family:var(--serif);font-size:clamp(26px,3.4vw,32px);font-weight:800;letter-spacing:.02em;line-height:1}

/* trust strip */
.trust{position:relative;background:var(--navy);color:#fff}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);max-width:var(--maxw);margin:0 auto}
.trust-item{padding:26px 20px;text-align:center;border-right:1px solid rgba(255,255,255,.14)}
.trust-item:last-child{border-right:none}
.trust-item .n{font-family:var(--serif);font-weight:800;font-size:clamp(28px,3.4vw,38px);line-height:1;color:#fff}
.trust-item .n small{font-size:.5em;font-weight:700;margin-left:2px}
.trust-item .t{font-size:12.5px;color:rgba(255,255,255,.82);font-weight:600;margin-top:8px;letter-spacing:.04em}

/* ---------- Section frame ---------- */
section.block{padding:96px 0}
section.alt{background:var(--base)}
section.sand{background:var(--sand)}
.sec-head{max-width:780px;margin:0 auto 52px;text-align:center}
.sec-head.left{text-align:left;margin-left:0}
.eyebrow{display:inline-block;font-size:12.5px;font-weight:700;letter-spacing:.22em;color:var(--navy);margin-bottom:12px}
.eyebrow::before{content:"";display:inline-block;width:22px;height:2px;background:var(--navy);vertical-align:middle;margin-right:9px;margin-bottom:4px}
.sec-head.center .eyebrow::after{content:"";display:inline-block;width:22px;height:2px;background:var(--navy);vertical-align:middle;margin-left:9px;margin-bottom:4px}
h2.sec-title{font-family:var(--serif);font-weight:700;font-size:clamp(27px,3.4vw,36px);line-height:1.45;color:var(--ink)}
h2.sec-title em{font-style:normal;color:var(--navy)}
.sec-sub{margin-top:14px;color:var(--ink-soft);font-size:16px;text-wrap:pretty}

/* ---------- Reasons ---------- */
.reasons{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.rcard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:38px 30px;box-shadow:var(--shadow);transition:transform .25s,box-shadow .25s}
.rcard:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.rcard .ico{width:70px;height:70px;margin-bottom:20px;border-radius:18px;background:linear-gradient(135deg,var(--navy),var(--blue-bright));display:flex;align-items:center;justify-content:center;box-shadow:0 10px 22px rgba(21,22,107,.26)}
.rcard .num{font-family:var(--serif);font-size:12.5px;font-weight:700;letter-spacing:.12em;color:var(--blue-bright);margin-bottom:8px}
.rcard h3{font-family:var(--serif);font-weight:700;font-size:21px;line-height:1.5;margin-bottom:12px}
.rcard p{font-size:15px;color:var(--ink-soft);line-height:1.85}
.big-n{font-family:var(--serif);font-weight:800;color:var(--navy);font-size:1.55em;line-height:1}
.big-n .s{font-size:.5em}

/* ---------- Works slider ---------- */
.gallery-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;max-width:var(--maxw);margin:0 auto 32px;padding:0 24px}
.works-nav{display:flex;gap:14px;flex-shrink:0}
.works-nav button{width:56px;height:56px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--navy);cursor:pointer;display:grid;place-items:center;transition:background .2s ease,color .2s ease,border-color .2s ease,opacity .2s ease}
.works-nav button:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
.works-nav button:disabled{opacity:.3;cursor:default;background:#fff;color:var(--navy);border-color:var(--line)}
.works-slider{position:relative}
.works-track{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;max-width:var(--maxw);margin:0 auto;padding:6px 24px 14px;scrollbar-width:none;-ms-overflow-style:none}
.works-track::-webkit-scrollbar{display:none}
.gcard{position:relative;flex:0 0 360px;scroll-snap-align:start;border-radius:14px;overflow:hidden;background:var(--ph);box-shadow:var(--shadow);cursor:pointer;transition:transform .3s ease,box-shadow .3s ease}
.gcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.gcard .imgwrap{position:relative;aspect-ratio:4/3;overflow:hidden}
.gcard img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.gcard:hover img{transform:scale(1.06)}
.gcard .ph-in{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:#9a9a9a;font-weight:700;font-size:13px;letter-spacing:.06em}
.gcard .tag{position:absolute;top:12px;left:12px;background:var(--navy);color:#fff;font-size:11.5px;font-weight:700;padding:5px 12px;border-radius:100px;letter-spacing:.03em;z-index:2}
.gcard .tag.r{background:var(--blue-bright)}
.gcard .tag.e{background:#0e8a5f}
.gcard .tag.w{background:#b9722b}
.gcard .cap{padding:16px 18px 18px;background:#fff}
.gcard .cap h3{font-family:var(--serif);font-weight:700;font-size:16.5px;line-height:1.45}
.gcard .cap p{font-size:12.5px;color:var(--ink-soft);margin-top:4px}
.gallery-cta{text-align:center;margin-top:42px}

/* ---------- Services ---------- */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.scard{background:#fff;border:1px solid var(--line);border-radius:14px;padding:32px 28px;transition:transform .25s,box-shadow .25s,border-color .25s}
.scard:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--navy)}
.scard .ico{width:54px;height:54px;border-radius:12px;background:var(--base);display:flex;align-items:center;justify-content:center;margin-bottom:18px;border:1px solid var(--line)}
.scard h3{font-family:var(--serif);font-weight:700;font-size:20px;margin-bottom:10px;display:flex;align-items:baseline;gap:9px}
.scard h3 .en{font-family:var(--sans);font-size:10.5px;font-weight:700;letter-spacing:.1em;color:var(--blue-bright)}
.scard p{font-size:14.5px;color:var(--ink-soft);line-height:1.8}

/* ---------- Process / flow ---------- */
.flow{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;counter-reset:step}
.fstep{position:relative;background:#fff;border:1px solid var(--line);border-radius:14px;padding:28px 18px 24px;text-align:center}
.fstep .step-n{counter-increment:step;width:42px;height:42px;margin:0 auto 14px;border-radius:50%;background:var(--navy);color:#fff;font-family:var(--serif);font-weight:800;font-size:18px;display:flex;align-items:center;justify-content:center}
.fstep .step-n::before{content:counter(step)}
.fstep h3{font-family:var(--serif);font-weight:700;font-size:16px;margin-bottom:8px;line-height:1.45}
.fstep p{font-size:12.5px;color:var(--ink-soft);line-height:1.7}
.flow-note{margin-top:34px;text-align:center;font-size:15px;color:var(--ink-soft)}
.flow-note b{color:var(--navy)}

/* ---------- About ---------- */
.about-grid{display:grid;grid-template-columns:400px 1fr;gap:56px;align-items:start}
.about-photo{position:relative}
.about-photo img{width:100%;height:480px;object-fit:cover;border-radius:16px;box-shadow:var(--shadow-lg)}
.about-photo .cap{margin-top:13px;text-align:center;font-size:13px;color:var(--ink-soft);font-weight:700}
.about-body h2{font-family:var(--serif);font-weight:700;font-size:clamp(25px,3vw,33px);line-height:1.55;margin-bottom:22px;color:var(--ink)}
.about-body h2 em{font-style:normal;color:var(--navy)}
.msg{font-size:16.5px;line-height:2;color:var(--ink-soft);margin-bottom:14px}
.sign{font-family:var(--serif);font-weight:700;font-size:17px;margin:22px 0 34px}
.sign small{display:block;font-family:var(--sans);font-size:13px;font-weight:500;color:var(--ink-soft);letter-spacing:.05em;margin-bottom:5px}
table.company{width:100%;border-collapse:collapse;font-size:14.5px}
table.company th,table.company td{text-align:left;padding:15px 8px;border-bottom:1px solid var(--line);vertical-align:top}
table.company th{width:120px;color:var(--navy);font-weight:700;white-space:nowrap}

/* ---------- Voice (testimonials) ---------- */
.voices{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.vcard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:32px 28px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:14px}
.vcard .stars{color:#f5a623;font-size:16px;letter-spacing:2px}
.vcard .qt{font-family:var(--serif);font-weight:700;font-size:18px;line-height:1.6;color:var(--ink)}
.vcard p{font-size:14px;color:var(--ink-soft);line-height:1.8}
.vcard .who{margin-top:auto;font-size:13px;color:var(--ink-soft);font-weight:700;border-top:1px solid var(--line);padding-top:14px}
.voice-disclaim{text-align:center;font-size:12px;color:var(--ink-soft);margin-top:24px}

/* ---------- News ---------- */
.news-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:start}
.news-list{display:flex;flex-direction:column}
.news-item{display:flex;gap:18px;align-items:baseline;padding:18px 4px;border-bottom:1px solid var(--line);transition:background .2s}
.news-item:hover{background:var(--base)}
.news-item time{font-size:13px;color:var(--ink-soft);font-weight:700;white-space:nowrap;font-variant-numeric:tabular-nums}
.news-item .ncat{font-size:11px;font-weight:700;color:#fff;background:var(--navy);padding:3px 10px;border-radius:100px;white-space:nowrap}
.news-item .ncat.ev{background:#b9722b}
.news-item h3{font-size:15px;font-weight:500;line-height:1.6}
.news-side{background:var(--navy);color:#fff;border-radius:18px;padding:38px 34px}
.news-side h3{font-family:var(--serif);font-size:22px;font-weight:700;margin-bottom:12px}
.news-side p{font-size:14.5px;color:rgba(255,255,255,.85);line-height:1.85;margin-bottom:24px}

/* ---------- CTA band ---------- */
.cta-band{background:var(--navy);color:#fff;text-align:center;padding:72px 24px}
.cta-band h2{font-family:var(--serif);font-weight:800;font-size:clamp(24px,3.4vw,36px);line-height:1.4;margin-bottom:14px}
.cta-band p{font-size:16px;color:rgba(255,255,255,.92);margin-bottom:30px}
.cta-band .actions{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;align-items:center}
.cta-band .bigtel{display:inline-flex;flex-direction:column;align-items:center;gap:2px;color:#fff}
.cta-band .bigtel small{font-size:12px;opacity:.85;letter-spacing:.08em;font-weight:700}
.cta-band .bigtel .num{font-family:var(--serif);font-size:clamp(30px,4.4vw,42px);font-weight:800;letter-spacing:.02em;line-height:1.1}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.ccard{background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:18px;padding:38px;box-shadow:var(--shadow)}
.ccard h3{font-family:var(--serif);font-weight:700;font-size:21px;margin-bottom:8px;color:var(--navy)}
.ccard .note{font-size:14px;color:var(--ink-soft);margin-bottom:20px}
.tel-box{text-align:center;border:2px dashed var(--line);border-radius:14px;padding:24px 16px;display:block;background:var(--base)}
.tel-box small{display:block;font-size:12px;font-weight:700;letter-spacing:.1em;color:var(--ink-soft);margin-bottom:6px}
.tel-box .num{font-family:var(--serif);font-weight:800;font-size:clamp(32px,5vw,44px);color:var(--navy);line-height:1.05}
.tel-box .hours{margin-top:8px;font-size:13px;color:var(--ink-soft)}
.tel-box:hover .num{color:var(--blue-bright)}
.map-wrap{margin-top:18px;border-radius:14px;overflow:hidden;border:1px solid var(--line)}
.map-wrap iframe{display:block;width:100%;height:230px;border:0}
.addr-line{display:flex;align-items:flex-start;gap:10px;font-size:14.5px;color:var(--ink-soft);margin-top:16px;line-height:1.7}
.addr-line svg{flex-shrink:0;margin-top:3px}
form .field{margin-bottom:15px}
form label{display:block;font-size:13.5px;font-weight:700;margin-bottom:6px}
form label .req{color:#d23;font-size:11px;margin-left:6px}
form input,form textarea{width:100%;border:1px solid var(--line);border-radius:8px;padding:13px 14px;font-family:var(--sans);font-size:15px;background:#fbfcff;color:var(--ink)}
form input:focus,form textarea:focus{outline:none;border-color:var(--navy);background:#fff;box-shadow:0 0 0 3px rgba(21,22,107,.12)}
form textarea{resize:vertical;min-height:96px}
form .btn{width:100%}

/* ---------- Footer ---------- */
footer.site{background:var(--ink);color:#cfd0e8;padding:58px 0 26px}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;padding-bottom:38px;border-bottom:1px solid rgba(255,255,255,.12)}
.foot-logo .chip{background:#fff;border-radius:12px;padding:10px 14px;display:inline-flex}
.foot-logo .chip img{height:64px;width:auto;display:block}
.foot-desc{font-size:14px;line-height:1.9;color:#9a9bc4;max-width:340px;margin-top:18px}
.foot-tel{font-family:var(--serif);font-size:28px;font-weight:800;color:#fff;display:inline-block;margin:6px 0 4px}
.foot-col h4{font-size:13px;font-weight:700;letter-spacing:.08em;color:#fff;margin-bottom:16px}
.foot-col a,.foot-col p{display:block;font-size:14px;color:#9a9bc4;margin-bottom:11px;line-height:1.7}
.foot-col a:hover{color:#fff}
.copy{padding-top:24px;text-align:center;font-size:12.5px;color:#7475a3;letter-spacing:.03em}

/* ---------- Sticky mobile call bar ---------- */
.mobile-cta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:90;background:#fff;border-top:1px solid var(--line);padding:10px 14px;gap:10px;box-shadow:0 -6px 20px rgba(0,0,0,.08)}
.mobile-cta a{flex:1;min-height:52px;font-size:15px}

/* ---------- Reveal animations (gentle) ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal-x{opacity:0;transform:translateX(-48px);transition:opacity .8s ease,transform .8s ease}
.reveal.in,.reveal-x.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}.d5{transition-delay:.4s}
@media (prefers-reduced-motion:reduce){
  .reveal,.reveal-x{opacity:1;transform:none;transition:none}
}

/* ---------- Mobile menu ---------- */
.m-panel{position:fixed;inset:0 0 0 auto;width:min(82vw,340px);background:#fff;z-index:200;transform:translateX(100%);transition:transform .3s ease;box-shadow:-10px 0 40px rgba(0,0,0,.18);padding:26px 24px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}
.m-panel.open{transform:none}
.m-overlay{position:fixed;inset:0;background:rgba(10,10,40,.45);z-index:150;opacity:0;visibility:hidden;transition:.3s}
.m-overlay.open{opacity:1;visibility:visible}
.m-panel .mclose{align-self:flex-end;width:42px;height:42px;border:1px solid var(--line);border-radius:8px;background:#fff;font-size:22px;color:var(--navy);cursor:pointer;line-height:1}
.m-panel a.mlink{padding:15px 8px;border-bottom:1px solid var(--line);font-weight:700;font-size:16px;color:var(--ink)}
.m-panel .m-tel{margin-top:22px;text-align:center;background:var(--base);border-radius:12px;padding:18px}
.m-panel .m-tel small{display:block;font-size:12px;color:var(--ink-soft);font-weight:700;margin-bottom:4px}
.m-panel .m-tel b{font-family:var(--serif);font-size:27px;color:var(--navy);font-weight:800}

/* ---------- Lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:300;background:rgba(10,12,40,.9);display:none;align-items:center;justify-content:center;padding:24px;flex-direction:column;gap:16px}
.lightbox.open{display:flex}
.lightbox img{max-width:min(92vw,1000px);max-height:78vh;border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.lightbox .lb-cap{color:#fff;font-family:var(--serif);font-size:18px;text-align:center}
.lightbox .lb-close{position:absolute;top:22px;right:26px;width:48px;height:48px;border-radius:50%;border:1px solid rgba(255,255,255,.4);background:rgba(255,255,255,.1);color:#fff;font-size:26px;cursor:pointer}

/* ---------- Responsive ---------- */
@media (max-width:1023px){
  nav.main,.head-cta{display:none}
  .hamburger{display:flex}
  .head-mtel{display:flex}
  .head-inner{height:66px;gap:12px}
  .logo-img{height:46px}
  .flow{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:980px){
  .hero::before{background:linear-gradient(180deg,rgba(255,255,255,.93) 0%,rgba(255,255,255,.8) 100%)}
  .about-grid{grid-template-columns:1fr;gap:34px}
  .about-photo img{height:360px}
  .news-grid{grid-template-columns:1fr;gap:30px}
  .reasons,.services,.voices{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  section.block{padding:70px 0}
  body{padding-bottom:72px}
  .mobile-cta{display:flex}
}
@media (max-width:620px){
  .wrap,.hero-inner,.gallery-head{padding-left:18px;padding-right:18px}
  .trust-grid{grid-template-columns:repeat(2,1fr)}
  .trust-item:nth-child(2){border-right:none}
  .trust-item:nth-child(1),.trust-item:nth-child(2){border-bottom:1px solid rgba(255,255,255,.14)}
  .flow{grid-template-columns:repeat(2,1fr)}
  .gallery-head{flex-direction:column;align-items:flex-start;gap:18px}
  .gcard{flex-basis:280px}
  .ccard{padding:28px 20px}
  .rcard,.scard{padding:28px 22px}
}
