﻿/**
 * A — Ever Corporate ワンページ専用スタイル
 * （元: a-corporate/Ever Corporate (1).html 内の <style>）
 */

:root{
    --navy:#0f2647;
    --navy-2:#1a3460;
    --navy-3:#26456f;
    --ink:#1e293b;
    --text:#1f2937;
    --muted:#5a6b80;
    --line:#dde3ec;
    --line-2:#c7d1de;
    --bg:#ffffff;
    --bg-2:#f4f6fa;
    --bg-3:#eaeef4;
    --accent:#0f2647;
    --serif:'Noto Serif JP', serif;
    --sans:'Noto Sans JP', system-ui, sans-serif;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{background:var(--bg);color:var(--text);font-family:var(--sans);font-weight:400;font-size:15px;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}

  /* サイト全体の最大幅 */
  .ac-site{
    max-width:1200px;
    margin-left:auto;
    margin-right:auto;
    position:relative;
  }
  a{color:inherit;text-decoration:none}
  button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
  img{display:block;max-width:100%}

  /* ============ NAV ============ */
  .nav{
    position:fixed;top:0;left:50%;transform:translateX(-50%);z-index:50;
    width:100%;max-width:1200px;
    display:grid;grid-template-columns:auto 1fr auto;align-items:center;
    padding:18px 40px;background:rgba(255,255,255,.96);
    border-bottom:1px solid var(--line);
    transition:padding .25s;
  }
  .nav.scrolled{padding:12px 40px;box-shadow:0 1px 0 var(--line)}
  .brand{display:flex;align-items:center;gap:12px}
  .brand-logo{
    width:38px;height:38px;background:var(--navy);color:#fff;
    display:grid;place-items:center;font-family:var(--serif);font-weight:600;font-size:20px;
  }
  .brand-text{line-height:1.1}
  .brand-text .a{font-family:var(--serif);font-weight:600;font-size:17px;letter-spacing:.04em;color:var(--navy)}
  .brand-text .b{font-size:10.5px;letter-spacing:.18em;color:var(--muted);margin-top:3px}

  .menu{display:flex;justify-content:center;gap:38px}
  .menu a{
    font-size:13.5px;font-weight:500;letter-spacing:.06em;color:var(--ink);
    padding:8px 0;position:relative;
  }
  .menu a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:var(--navy);transition:right .35s}
  .menu a:hover::after{right:0}
  .menu a small{display:block;font-size:9.5px;letter-spacing:.18em;color:var(--muted);margin-top:2px;font-weight:400}

  .nav-right{display:flex;align-items:center;gap:14px}
  .nav-tel{font-size:13px;color:var(--muted);letter-spacing:.04em}
  .nav-tel strong{color:var(--navy);font-family:var(--serif);font-weight:600;font-size:18px;margin-left:6px;letter-spacing:.02em}
  .btn{
    display:inline-flex;align-items:center;gap:10px;
    padding:13px 22px;font-size:13px;font-weight:500;letter-spacing:.08em;
    transition:background .2s, color .2s, border-color .2s;
  }
  .btn-primary{background:var(--navy);color:#fff;border:1px solid var(--navy)}
  .btn-primary:hover{background:var(--navy-2)}
  .btn-line{background:transparent;color:var(--navy);border:1px solid var(--navy)}
  .btn-line:hover{background:var(--navy);color:#fff}
  .btn .arr{font-size:14px}

  /* ============ HERO ============ */
  .hero{
    position:relative;min-height:88vh;
    display:grid;grid-template-columns:1.1fr 1.4fr;gap:0;align-items:end;
    padding-top:120px;
  }
  .hero-left{padding:60px 40px 80px 60px}
  .hero-num{
    font-family:var(--serif);font-size:13px;color:var(--muted);letter-spacing:.18em;margin-bottom:24px;
  }
  .hero h1{
    font-family:var(--serif);font-weight:500;
    font-size:clamp(36px,4.4vw,60px);line-height:1.45;letter-spacing:.04em;color:var(--navy);
    margin-bottom:32px;
  }
  .hero h1 .em{
    border-bottom:2px solid var(--navy);padding-bottom:4px;
  }
  .hero p.lead{
    font-size:14.5px;line-height:2.05;color:var(--text);max-width:460px;letter-spacing:.04em;margin-bottom:38px;
  }
  .hero-actions{display:flex;gap:14px}

  .hero-right{
    position:relative;height:75vh;min-height:520px;
  }
  .hero-photo{
    position:absolute;inset:0;
    background:#1a2a40;
    overflow:hidden;
  }
  .hero-photo img{width:100%;height:100%;object-fit:cover;filter:brightness(.78) contrast(1.05) saturate(.85)}
  .hero-photo::before{
    content:"";position:absolute;inset:0;z-index:1;
    background:linear-gradient(180deg, rgba(15,38,71,.0) 40%, rgba(15,38,71,.55) 100%);
  }
  .hero-photo-cap{
    position:absolute;left:32px;bottom:24px;z-index:2;
    color:rgba(255,255,255,.85);font-size:11px;letter-spacing:.18em;
  }
  .hero-photo-cap .ttl{font-family:var(--serif);font-size:14px;color:#fff;letter-spacing:.06em;margin-bottom:4px}

  .hero-tag{
    position:absolute;top:60px;left:-30px;
    background:#fff;padding:18px 26px;border:1px solid var(--line);
    box-shadow:0 1px 0 var(--line);
  }
  .hero-tag .k{font-size:10.5px;letter-spacing:.22em;color:var(--muted);margin-bottom:6px}
  .hero-tag .v{font-family:var(--serif);font-size:22px;color:var(--navy);font-weight:600;letter-spacing:.04em}

  /* breadcrumb / pagination indicator */
  .hero-meta{
    position:absolute;left:60px;bottom:24px;display:flex;align-items:center;gap:14px;
    font-size:11.5px;letter-spacing:.18em;color:var(--muted);
  }
  .hero-meta .line{width:36px;height:1px;background:var(--line-2)}

  /* ============ INFO BAR ============ */
  .info-bar{
    border-top:1px solid var(--line);border-bottom:1px solid var(--line);
    display:grid;grid-template-columns:repeat(4,1fr);background:var(--bg);
  }
  .info-bar .cell{
    padding:30px 32px;border-right:1px solid var(--line);
    display:flex;flex-direction:column;gap:6px;
  }
  .info-bar .cell:last-child{border-right:0}
  .info-bar .k{font-size:11px;letter-spacing:.22em;color:var(--muted)}
  .info-bar .v{font-family:var(--serif);font-size:18px;font-weight:500;color:var(--navy);letter-spacing:.04em}
  .info-bar .s{font-size:12px;color:var(--text)}

  /* ============ SECTION ============ */
  .section{padding:120px 60px;position:relative}
  .section-grey{background:var(--bg-2)}
  .section-head{margin-bottom:60px;display:grid;grid-template-columns:280px 1fr;gap:60px;align-items:end}
  .section-head .ti{
    font-size:11px;letter-spacing:.32em;color:var(--navy);font-weight:500;margin-bottom:12px;
    display:flex;align-items:center;gap:14px;
  }
  .section-head .ti::before{content:"";width:24px;height:1px;background:var(--navy)}
  .section-head h2{
    font-family:var(--serif);font-weight:500;
    font-size:clamp(28px,3.2vw,40px);line-height:1.4;letter-spacing:.06em;color:var(--navy);
  }
  .section-head .desc{font-size:14px;line-height:2;color:var(--text);max-width:540px;letter-spacing:.04em}

  /* ============ ABOUT ============ */
  .about{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:start}
  .about p{font-size:14.5px;line-height:2.1;color:var(--text);letter-spacing:.04em}
  .about p + p{margin-top:22px}
  .about-photo{
    position:relative;aspect-ratio:4/5;
    background:#1a2a40;
    overflow:hidden;
  }
  .about-photo img{width:100%;height:100%;object-fit:cover;filter:contrast(1.02)}
  .about-photo .cap{position:absolute;left:24px;bottom:20px;color:rgba(255,255,255,.92);font-size:11px;letter-spacing:.2em;z-index:2;text-shadow:0 1px 6px rgba(0,0,0,.6)}
  .about-photo .cap b{font-family:var(--serif);font-weight:500;display:block;font-size:14px;letter-spacing:.06em;margin-bottom:4px;color:#fff}

  .about-bullets{margin-top:40px;border-top:1px solid var(--line)}
  .about-bullets .b{display:grid;grid-template-columns:140px 1fr;gap:24px;padding:20px 0;border-bottom:1px solid var(--line);align-items:start}
  .about-bullets .b .k{font-family:var(--serif);font-weight:500;color:var(--navy);font-size:14.5px;letter-spacing:.08em}
  .about-bullets .b .v{font-size:13.5px;line-height:1.95;color:var(--text);letter-spacing:.04em}

  /* ============ SERVICE ============ */
  .service-list{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
  .svc{
    background:#fff;padding:48px 44px;display:grid;grid-template-columns:60px 1fr;gap:30px;
    transition:background .2s;
  }
  .svc:hover{background:var(--bg-2)}
  .svc-num{font-family:var(--serif);font-size:14px;color:var(--muted);letter-spacing:.06em;padding-top:6px}
  .svc h3{font-family:var(--serif);font-weight:500;font-size:22px;color:var(--navy);letter-spacing:.06em;margin-bottom:6px}
  .svc .en{font-size:11.5px;letter-spacing:.22em;color:var(--muted);margin-bottom:20px}
  .svc p{font-size:13.5px;line-height:1.95;color:var(--text);letter-spacing:.04em;margin-bottom:18px}
  .svc .more{font-size:12.5px;letter-spacing:.14em;color:var(--navy);font-weight:500;display:inline-flex;align-items:center;gap:8px;border-bottom:1px solid var(--navy);padding-bottom:3px}
  .svc .more:hover{color:var(--navy-2)}

  /* ============ WORKS ============ */
  .works-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
  .work{background:#fff;border:1px solid var(--line);transition:border-color .2s}
  .work:hover{border-color:var(--navy-3)}
  .work-img{aspect-ratio:4/3;background:#26456f;position:relative;overflow:hidden}
  .work-img img{width:100%;height:100%;object-fit:cover;filter:saturate(.85) contrast(1.04)}
  .work-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, transparent 60%, rgba(0,0,0,.25) 100%);pointer-events:none}
  .work-tag{position:absolute;top:16px;left:16px;background:rgba(255,255,255,.95);color:var(--navy);padding:5px 12px;font-size:10.5px;letter-spacing:.18em;font-weight:500;z-index:2}
  .work-body{padding:24px}
  .work-body .cat{font-size:11px;letter-spacing:.18em;color:var(--muted);margin-bottom:8px}
  .work-body h3{font-family:var(--serif);font-weight:500;font-size:18px;color:var(--navy);line-height:1.6;letter-spacing:.04em;margin-bottom:10px}
  .work-body p{font-size:13px;line-height:1.85;color:var(--text);letter-spacing:.04em}

  .more-row{display:flex;justify-content:center;margin-top:60px}

  /* ============ NEWS ============ */
  .news-row{display:grid;grid-template-columns:1fr 2fr;gap:80px;align-items:start}
  .news-list{display:flex;flex-direction:column}
  .news-item{
    display:grid;grid-template-columns:120px 92px 1fr auto;gap:24px;align-items:center;
    padding:22px 4px;border-bottom:1px solid var(--line);transition:padding .2s;
  }
  .news-item:hover{padding-left:12px}
  .news-item:first-child{border-top:1px solid var(--line)}
  .news-item .date{font-size:13px;color:var(--muted);letter-spacing:.06em}
  .news-item .cat{font-size:10.5px;letter-spacing:.18em;text-align:center;padding:4px 8px;border:1px solid var(--line-2);color:var(--text)}
  .news-item .cat.press{border-color:var(--navy);color:var(--navy);font-weight:500}
  .news-item .ttl{font-size:14px;line-height:1.7;color:var(--text);letter-spacing:.04em}
  .news-item .arr{color:var(--muted);font-size:14px}
  .news-item:hover .arr{color:var(--navy)}

  /* ============ COMPANY ============ */
  .company{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:start}
  .company-table{border-top:1px solid var(--line)}
  .company-table .row{display:grid;grid-template-columns:200px 1fr;padding:20px 0;border-bottom:1px solid var(--line);align-items:start;gap:24px}
  .company-table .k{font-size:13px;color:var(--muted);letter-spacing:.06em;font-weight:500}
  .company-table .v{font-size:14px;line-height:1.85;color:var(--text);letter-spacing:.04em}

  .map-card{background:#fff;border:1px solid var(--line);padding:0;overflow:hidden}
  .map-img{
    aspect-ratio:16/10;
    background:#dbe3ee;
    position:relative;overflow:hidden;
  }
  .map-img img{width:100%;height:100%;object-fit:cover;filter:saturate(.6) contrast(.95)}
  .map-img::after{
    content:"";position:absolute;left:48%;top:42%;width:14px;height:14px;
    border-radius:50%;background:var(--navy);z-index:2;
    box-shadow:0 0 0 5px rgba(15,38,71,.18), 0 0 0 12px rgba(15,38,71,.08);
  }
  .map-cap{padding:20px 24px;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line)}
  .map-cap .a{font-family:var(--serif);font-size:15px;color:var(--navy);font-weight:500}
  .map-cap .b{font-size:12px;color:var(--muted);letter-spacing:.04em}

  /* ============ RECRUIT ============ */
  .recruit{
    background:var(--navy);color:#fff;
    padding:100px 60px;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
  }
  .recruit .ti{color:rgba(255,255,255,.85)}
  .recruit .ti::before{background:rgba(255,255,255,.7)}
  .recruit h2{
    font-family:var(--serif);font-weight:500;
    font-size:clamp(28px,3.6vw,46px);line-height:1.5;letter-spacing:.06em;color:#fff;margin-bottom:24px;
  }
  .recruit p{font-size:14.5px;line-height:2.1;color:rgba(255,255,255,.82);max-width:460px;letter-spacing:.04em;margin-bottom:30px}
  .recruit-side{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.18)}
  .recruit-side a{
    background:var(--navy);padding:32px 28px;display:flex;flex-direction:column;gap:8px;
    transition:background .2s;
  }
  .recruit-side a:hover{background:var(--navy-2)}
  .recruit-side .en{font-size:11px;letter-spacing:.24em;color:rgba(255,255,255,.65)}
  .recruit-side .jp{font-family:var(--serif);font-size:18px;color:#fff;letter-spacing:.06em}
  .recruit-side .arr{margin-top:20px;font-size:18px;color:rgba(255,255,255,.7)}

  /* ============ CONTACT ============ */
  .contact{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
  .contact-left h2 + p{margin-top:24px}
  .contact-left p{font-size:14.5px;line-height:2.1;color:var(--text);max-width:440px;letter-spacing:.04em}
  .contact-info{margin-top:40px;border-top:1px solid var(--line)}
  .contact-info .row{display:grid;grid-template-columns:120px 1fr;padding:18px 0;border-bottom:1px solid var(--line);gap:20px}
  .contact-info .k{font-size:12px;color:var(--muted);letter-spacing:.18em;padding-top:4px}
  .contact-info .v{font-family:var(--serif);font-size:18px;color:var(--navy);font-weight:500;letter-spacing:.04em}
  .contact-info .s{font-size:12px;color:var(--muted);margin-top:4px;font-family:var(--sans);font-weight:400;letter-spacing:.04em}

  .contact-card{
    background:var(--bg-2);padding:40px;border:1px solid var(--line);
  }
  .contact-card .field{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
  .contact-card .row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:0}
  .contact-card label{font-size:12px;color:var(--muted);letter-spacing:.08em}
  .contact-card label .req{color:#b13c3c;margin-left:4px}
  .contact-card input, .contact-card textarea, .contact-card select{
    background:#fff;border:1px solid var(--line-2);padding:13px 14px;
    font-family:var(--sans);font-size:14px;color:var(--text);
    transition:border-color .2s;
  }
  .contact-card input:focus, .contact-card textarea:focus, .contact-card select:focus{outline:none;border-color:var(--navy)}
  .contact-card textarea{resize:vertical;min-height:120px}
  .contact-submit{
    width:100%;background:var(--navy);color:#fff;padding:18px;
    font-size:14px;font-weight:500;letter-spacing:.16em;
    display:inline-flex;justify-content:center;align-items:center;gap:12px;
    border:0;cursor:pointer;transition:background .2s;
  }
  .contact-submit:hover{background:var(--navy-2)}

  /* ============ FOOTER ============ */
  footer{background:#0a1a30;color:rgba(255,255,255,.78);padding:70px 60px 24px;font-size:13px}
  .ft-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:50px;padding-bottom:50px;border-bottom:1px solid rgba(255,255,255,.12)}
  .ft-brand h3{font-family:var(--serif);font-weight:500;font-size:22px;color:#fff;letter-spacing:.06em;margin-bottom:14px}
  .ft-brand p{line-height:1.95;color:rgba(255,255,255,.65);max-width:340px;letter-spacing:.04em;font-size:13px}
  .ft-brand .addr{margin-top:18px;font-size:12px;color:rgba(255,255,255,.55);line-height:1.85}
  .ft-col h4{font-size:11px;letter-spacing:.22em;color:rgba(255,255,255,.55);margin-bottom:20px;font-weight:500}
  .ft-col ul{list-style:none;display:flex;flex-direction:column;gap:11px}
  .ft-col a{color:rgba(255,255,255,.85);font-size:13px;letter-spacing:.04em;transition:color .2s}
  .ft-col a:hover{color:#fff}
  .ft-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;font-size:11.5px;letter-spacing:.08em;color:rgba(255,255,255,.5)}
  .ft-bottom .lks a{margin-left:20px;color:rgba(255,255,255,.55)}
  .ft-bottom .lks a:hover{color:#fff}

  /* reveal */
  .reveal{opacity:0;transform:translateY(24px);transition:opacity .9s ease, transform .9s cubic-bezier(.7,0,.2,1)}
  .reveal.in{opacity:1;transform:none}

  /* ============ tablet & SP ============ */
  @media (max-width:1024px){
    .nav-tel{display:none}
    .nav{
      grid-template-columns:1fr auto;
      grid-template-rows:auto auto;
      row-gap:10px;
      column-gap:12px;
      padding:12px max(16px, env(safe-area-inset-right)) 10px max(16px, env(safe-area-inset-left));
      align-items:center;
    }
    .nav.scrolled{padding-top:10px;padding-bottom:8px}
    .brand{grid-column:1;grid-row:1;min-width:0}
    .brand-text .a{font-size:clamp(13px,3.6vw,17px)}
    .brand-text .b{font-size:9.5px;letter-spacing:.14em}
    .nav-right{grid-column:2;grid-row:1;align-self:center}
    .nav-right .btn{padding:12px 16px;font-size:12px;white-space:nowrap}
    .menu{
      display:flex;
      grid-column:1 / -1;
      grid-row:2;
      overflow-x:auto;
      gap:4px 18px;
      padding:10px 0 6px;
      margin:4px -4px 0;
      border-top:1px solid var(--line);
      justify-content:flex-start;
      -webkit-overflow-scrolling:touch;
      scrollbar-width:none;
      mask-image:linear-gradient(90deg, #000 92%, transparent);
    }
    .menu::-webkit-scrollbar{display:none}
    .menu a{
      flex:0 0 auto;
      white-space:nowrap;
      font-size:12.5px;
      padding:10px 2px 8px;
    }
    .menu a small{font-size:8.5px;letter-spacing:.14em}

    .hero{
      grid-template-columns:1fr;
      padding-top:clamp(100px, 28vw, 140px);
      min-height:auto;
    }
    .hero-left{padding:32px max(16px, env(safe-area-inset-left)) 40px max(16px, env(safe-area-inset-right))}
    .hero h1{font-size:clamp(26px, 7vw, 44px);margin-bottom:24px}
    .hero p.lead{font-size:14px;margin-bottom:28px}
    .hero-actions{flex-direction:column;align-items:stretch;gap:12px}
    .hero-actions .btn{justify-content:center;min-height:48px}
    .hero-right{height:52vh;min-height:280px;order:-1}
    .hero-photo-cap{left:16px;bottom:16px;right:16px;font-size:10px}
    .hero-photo-cap .ttl{font-size:13px}
    .hero-tag{left:max(12px, env(safe-area-inset-left));top:auto;bottom:12px;right:auto;padding:14px 18px}
    .hero-meta{
      left:max(16px, env(safe-area-inset-left));
      bottom:16px;
      font-size:10px;
      flex-wrap:wrap;
    }

    .info-bar{grid-template-columns:1fr 1fr}
    .info-bar .cell{padding:22px 18px}
    .info-bar .cell:nth-child(2){border-right:0}
    .info-bar .cell:nth-child(-n+2){border-bottom:1px solid var(--line)}
    .info-bar .v{font-size:16px}

    .section{padding:72px max(16px, env(safe-area-inset-left)) 72px max(16px, env(safe-area-inset-right))}
    .section-head{margin-bottom:44px;gap:16px}
    .section-head h2{font-size:clamp(22px, 5.5vw, 32px)}

    .about,.news-row,.company,.contact,.recruit{grid-template-columns:1fr;gap:36px}
    .about-photo{max-width:420px;margin:0 auto}
    .about-bullets .b{grid-template-columns:1fr;gap:8px;padding:18px 0}
    .about-bullets .b .k{font-size:13px}

    .service-list,.works-grid{grid-template-columns:1fr;gap:1px}
    .svc{padding:32px 22px;grid-template-columns:48px 1fr;gap:20px}
    .svc h3{font-size:19px}
    .works-grid{gap:20px}
    .work-body{padding:20px}

    .news-row{gap:36px}
    .news-item{
      display:grid;
      grid-template-columns:auto 1fr auto;
      grid-template-rows:auto auto;
      gap:8px 12px;
      padding:18px 0;
      align-items:center;
    }
    .news-item:hover{padding-left:0}
    .news-item .date{grid-column:1;grid-row:1}
    .news-item .cat{grid-column:3;grid-row:1;justify-self:end}
    .news-item .ttl{grid-column:1 / -1;grid-row:2;font-size:13.5px;line-height:1.65}
    .news-item .arr{display:none}

    .company-table .row{grid-template-columns:1fr;gap:8px;padding:16px 0}
    .company-table .k{padding-top:0}
    .map-cap{flex-direction:column;align-items:flex-start;gap:6px;padding:16px 18px}

    .recruit{padding:56px max(16px, env(safe-area-inset-left)) 56px max(16px, env(safe-area-inset-right))}
    .recruit-side{grid-template-columns:1fr}
    .recruit-side a{padding:22px 20px;min-height:56px}

    .contact-card{padding:28px 20px}
    .contact-card .row{grid-template-columns:1fr}
    .contact-info .row{grid-template-columns:1fr;gap:8px;padding:16px 0}
    .contact-info .k{padding-top:0}
    .contact-info .v{font-size:17px;word-break:break-word}
    .contact-submit{min-height:52px;padding:16px}

    .ft-top{grid-template-columns:1fr 1fr;gap:28px 20px}
    footer{padding:44px max(16px, env(safe-area-inset-left)) 20px max(16px, env(safe-area-inset-right))}
    .ft-bottom{flex-direction:column;align-items:flex-start;gap:14px}
    .ft-bottom .lks{display:flex;flex-wrap:wrap;gap:10px 16px;margin:0}
    .ft-bottom .lks a{margin-left:0}
  }

  @media (max-width:640px){
    .ac-site{padding-left:0;padding-right:0}
    .info-bar{grid-template-columns:1fr}
    .info-bar .cell{border-right:0;border-bottom:1px solid var(--line)}
    .info-bar .cell:last-child{border-bottom:0}
    .section{padding:56px max(14px, env(safe-area-inset-left)) 56px max(14px, env(safe-area-inset-right))}
    .more-row .btn{width:100%;max-width:100%;justify-content:center;min-height:48px}
    .news-item{
      grid-template-columns:1fr;
      grid-template-rows:auto auto auto auto;
    }
    .news-item .date{grid-column:1;grid-row:1}
    .news-item .cat{grid-column:1;grid-row:2;justify-self:start}
    .news-item .ttl{grid-column:1;grid-row:3}
    .news-item .arr{display:none}
    .ft-top{grid-template-columns:1fr;gap:28px}
    .ft-brand p{max-width:none}
    .hero-right{height:44vh;min-height:220px}
    .hero-tag{position:relative;left:auto;bottom:auto;margin:16px max(16px, env(safe-area-inset-left)) 0;box-shadow:none}
    .hero-meta{position:relative;left:auto;bottom:auto;margin:20px max(16px, env(safe-area-inset-left)) 0;padding-bottom:8px}
  }

