/*
Theme Name:   Sunao Child
Theme URI:    https://sunao-elec.co.jp/
Description:  東京スナオ電気株式会社 公式サイト用 Astra子テーマ。コーポレートサイト(トップページ)の独自レイアウト・お知らせ/取扱メーカー/動画CPT表示を含みます。
Author:       東京スナオ電気株式会社
Author URI:   https://sunao-elec.co.jp/
Template:     astra
Version:      1.0.0
Text Domain:  sunao-child
*/


*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;min-width:390px;}
body{background:#fff;color:#1a2236;font-family:'Zen Kaku Gothic New',sans-serif;line-height:1.75;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
a{color:inherit;text-decoration:none;}ul{list-style:none;}
h1,h2,h3,h4{font-family:'Zen Kaku Gothic New',sans-serif;font-weight:900;line-height:1.2;}
.container{max-width:1520px;margin:0 auto;padding:0 clamp(16px,4vw,64px);}
:root{
  --blue:#00a8cc;--blue-l:#00c4ef;--blue-s:rgba(0,168,204,.08);
  --blue-line:rgba(0,168,204,.22);--cyan:#00d4f5;
  --navy:#0d1829;
  --bg2:#eef8fb;--bg3:#dff0f7;
  --t1:#1a2236;--t2:#4a5a78;--t3:#8a9ab8;
  --bdr:rgba(0,168,204,.12);--bdr2:rgba(0,168,204,.2);
  --sh:0 6px 32px rgba(0,168,204,.15);--shd:0 16px 48px rgba(13,24,41,.1);
  --r:10px;--r2:18px;
  --ease:cubic-bezier(.4,0,.2,1);--bounce:cubic-bezier(.34,1.56,.64,1);
  --sp:clamp(64px,8vw,120px);
}
.tag{display:inline-flex;align-items:center;gap:10px;font-family:'Rajdhani',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);margin-bottom:14px;}
.tag::before{content:'';width:24px;height:1px;background:var(--blue);}
.sec-title{font-size:clamp(1.6rem,3vw,2.6rem);color:var(--navy);margin-bottom:14px;}
.sec-sub{font-size:.97rem;color:var(--t2);max-width:520px;line-height:1.9;}
section{padding:var(--sp) 0;}
.divider{height:1px;background:linear-gradient(90deg,transparent,var(--blue),transparent);opacity:.3;}
.btn{display:inline-flex;align-items:center;gap:10px;font-family:'Zen Kaku Gothic New',sans-serif;font-weight:700;font-size:.9rem;border-radius:4px;padding:12px 28px;cursor:pointer;border:none;transition:all .25s var(--bounce);letter-spacing:.04em;}
.btn svg{transition:transform .2s var(--bounce);}.btn:hover svg{transform:translateX(5px);}
.btn-blue{background:var(--blue);color:#fff;box-shadow:var(--sh);}
.btn-blue:hover{background:var(--blue-l);transform:translateY(-2px);box-shadow:0 12px 36px rgba(0,168,204,.3);}
.btn-ghost{background:transparent;color:var(--t2);border:1px solid var(--bdr2);}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-s);}
.btn-white{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.4);}
.btn-white:hover{background:rgba(255,255,255,.1);border-color:#fff;}
.rv{opacity:1;transform:none;transition:opacity .6s var(--ease),transform .6s var(--ease);}
.rv.out{opacity:0;transform:translateY(22px);}
.rv.in{opacity:1;transform:none;}
.d1{transition-delay:.1s;}.d2{transition-delay:.2s;}

/* ===== HEADER ===== */
#hdr{position:fixed;top:0;left:0;right:0;width:100%;box-sizing:border-box;z-index:500;overflow:visible;background:#fff;box-shadow:0 1px 0 var(--bdr);}
#hdr.sc{box-shadow:0 1px 0 var(--bdr),0 4px 20px rgba(13,24,41,.06);}
.hi{display:flex;align-items:center;justify-content:space-between;height:54px;padding:0 clamp(16px,4vw,64px);max-width:100%;}
.logo{display:flex;align-items:center;gap:0;}
.logo svg{height:36px;width:auto;}
nav{display:flex;align-items:center;gap:22px;}
nav a{font-family:'Rajdhani',sans-serif;font-size:.78rem;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--t2);transition:color .2s;position:relative;}
nav a::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1px;background:var(--blue);transform:scaleX(0);transition:transform .25s var(--bounce);}
nav a:hover{color:var(--blue);}nav a:hover::after{transform:scaleX(1);}

/* ===== HERO ===== */
#hero{min-height:100vh;display:flex;align-items:center;background:linear-gradient(150deg,#fff 0%,#eef8fb 55%,#dff0f7 100%);position:relative;overflow:hidden;}
.hg{position:absolute;inset:0;background-image:linear-gradient(rgba(0,168,204,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,168,204,.03) 1px,transparent 1px);background-size:80px 80px;mask-image:radial-gradient(ellipse 90% 90% at 50% 40%,black 30%,transparent 100%);}
.hglow{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;}
.hg1{width:560px;height:560px;background:radial-gradient(circle,rgba(0,168,204,.1),transparent 65%);top:-150px;right:-80px;animation:gf 10s ease-in-out infinite;}
.hg2{width:320px;height:320px;background:radial-gradient(circle,rgba(0,212,245,.07),transparent 65%);bottom:-80px;left:-60px;animation:gf 13s ease-in-out infinite reverse;}
@keyframes gf{0%,100%{transform:translate(0,0);}50%{transform:translate(22px,-22px);}}
@keyframes mascot-float{0%,100%{transform:translateY(0);}50%{transform:translateY(-10px);}}
.hero-mascot{width:250px;height:auto;filter:drop-shadow(2px 6px 16px rgba(0,0,0,.15));animation:mascot-float 3s ease-in-out infinite;}
@media(max-width:1200px){.hero-mascot{width:110px;}}
@media(max-width:900px){.hero-mascot{width:88px;}}
@media(max-width:600px){.hero-mascot-wrap{display:none;}}
.hero-in{display:grid;grid-template-columns:1fr;gap:64px;align-items:center;position:relative;z-index:1;padding:120px 0 80px;}
.h-ey{display:inline-flex;align-items:center;gap:10px;font-family:'Rajdhani',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--blue);margin-bottom:22px;}
.h-ey::before{content:'';width:24px;height:1px;background:var(--blue);}
.h1{font-size:clamp(2.2rem,5vw,5rem);font-weight:900;color:var(--navy);line-height:1.06;letter-spacing:-.02em;margin-bottom:8px;}
.h1 .grad{color:transparent;background:linear-gradient(130deg,var(--blue),var(--cyan));-webkit-background-clip:text;background-clip:text;}
.h1-en{font-family:'Rajdhani',sans-serif;font-size:clamp(.82rem,1.4vw,1.15rem);font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--t3);margin-bottom:28px;display:block;}
.h-lead{font-size:.97rem;color:var(--t2);max-width:460px;line-height:2;margin-bottom:40px;}
.h-acts{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:56px;}
.h-stats{display:flex;border-top:1px solid var(--bdr);padding-top:30px;max-width:480px;}
.hst{flex:1;padding-right:20px;margin-right:20px;border-right:1px solid var(--bdr);}
.hst:last-child{border:none;margin:0;padding:0;}
.hst-n{font-family:'Rajdhani',sans-serif;font-size:2rem;font-weight:700;line-height:1;background:linear-gradient(135deg,var(--navy),var(--blue));-webkit-background-clip:text;background-clip:text;color:transparent;}
.hst-l{font-size:.74rem;color:var(--t3);margin-top:4px;}
.h-vis{position:relative;}
.h-box{border-radius:var(--r2);aspect-ratio:4/3;background:linear-gradient(145deg,#e8f5f9,#cce8f3);border:1px solid var(--bdr);display:flex;align-items:center;justify-content:center;font-size:4rem;position:relative;overflow:hidden;box-shadow:var(--shd);}
.h-box::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(238,248,251,.8) 100%);}
.scan{position:absolute;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--blue),transparent);animation:sc 4s ease-in-out infinite;}
@keyframes sc{0%,100%{top:0;opacity:.4;}50%{top:100%;opacity:.7;}}
.vc{position:absolute;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);border:1px solid var(--bdr);border-radius:var(--r);padding:13px 18px;box-shadow:var(--shd);animation:vf 5s ease-in-out infinite;}
.vc:nth-child(2){bottom:-14px;left:-18px;}
.vc:nth-child(3){top:-12px;right:-16px;animation-delay:2.5s;}
@keyframes vf{0%,100%{transform:translateY(0);}50%{transform:translateY(-7px);}}
.vc-l{font-family:'Rajdhani',sans-serif;font-size:.58rem;letter-spacing:.13em;text-transform:uppercase;color:var(--t3);margin-bottom:3px;}
.vc-v{font-family:'Rajdhani',sans-serif;font-size:1.4rem;font-weight:700;color:var(--navy);line-height:1;}
.vc-s{font-size:.68rem;color:var(--t2);margin-top:2px;}
.dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--cyan);margin-right:5px;animation:bl 1.5s infinite;}
@keyframes bl{0%,100%{opacity:1;}50%{opacity:.2;}}

/* ===== TICKER ===== */
#ticker{background:#eef8fb;border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr);display:flex;align-items:stretch;overflow:hidden;height:46px;}
.tk-lbl{flex-shrink:0;width:100px;background:var(--blue);display:flex;align-items:center;justify-content:center;font-family:'Rajdhani',sans-serif;font-size:.66rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:#fff;position:relative;z-index:2;clip-path:polygon(0 0,calc(100% - 11px) 0,100% 50%,calc(100% - 11px) 100%,0 100%);}
.tk-wrap{flex:1;overflow:hidden;display:flex;align-items:center;padding-left:20px;position:relative;}
.tk-wrap::after{content:'';position:absolute;right:0;top:0;bottom:0;width:60px;background:linear-gradient(to left,#eef8fb,transparent);pointer-events:none;z-index:1;}
.tk-track{display:flex;gap:48px;white-space:nowrap;animation:tkr 32s linear infinite;will-change:transform;}
@keyframes tkr{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}
.tk-item{font-size:.82rem;font-weight:700;color:var(--t2);display:inline-flex;align-items:center;gap:9px;flex-shrink:0;}
.tk-item a{color:var(--t2);transition:color .2s;}.tk-item a:hover{color:var(--blue);}
.tk-sep{color:var(--blue);font-size:.52rem;}

/* ===== SERVICES ===== */
#svcs{background:#eef8fb;}
.sec-row{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:52px;}
.sg{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--bdr);}
.sc{background:#eef8fb;padding:36px 30px;position:relative;overflow:hidden;transition:background .3s;cursor:pointer;}
.sc::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--blue),transparent);transform:scaleX(0);transition:transform .4s;}
.sc::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--blue-s),transparent);opacity:0;transition:opacity .3s;}
.sc:hover{background:#dff0f7;}.sc:hover::before{transform:scaleX(1);}.sc:hover::after{opacity:1;}
.sc>*{position:relative;z-index:1;}
.sc-n{font-family:'Rajdhani',sans-serif;font-size:3.4rem;font-weight:700;color:rgba(0,168,204,.07);line-height:1;margin-bottom:2px;}
.sc-ico{width:46px;height:46px;border-radius:var(--r);background:var(--blue-s);border:1px solid var(--blue-line);display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:16px;transition:transform .3s var(--bounce);}
.sc:hover .sc-ico{transform:scale(1.08) rotate(-4deg);}
.sc h3{font-size:.98rem;font-weight:900;color:var(--navy);margin-bottom:9px;}
.sc p{font-size:.85rem;color:var(--t2);line-height:1.8;}
.sc-lk{display:inline-flex;align-items:center;gap:5px;margin-top:14px;font-family:'Rajdhani',sans-serif;font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);transition:gap .2s;}
.sc:hover .sc-lk{gap:9px;}

/* ===== MAKER TIEUP ===== */
#makers{background:#fff;}
.maker-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.mk{background:#eef8fb;border:1px solid var(--bdr);border-radius:var(--r2);padding:28px 24px;transition:all .3s;cursor:pointer;position:relative;overflow:hidden;}
.mk:hover{transform:translateY(-3px);box-shadow:var(--shd);border-color:var(--blue-line);}
.mk::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue),var(--cyan));opacity:0;transition:opacity .3s;}
.mk:hover::before{opacity:1;}
.mk-badge{display:inline-flex;font-family:'Rajdhani',sans-serif;font-size:.6rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;background:var(--blue);color:#fff;padding:3px 10px;border-radius:2px;margin-bottom:14px;}
.mk h3{font-size:1rem;font-weight:900;color:var(--navy);margin-bottom:8px;}
.mk-maker{font-family:'Rajdhani',sans-serif;font-size:.72rem;font-weight:700;color:var(--blue);letter-spacing:.06em;margin-bottom:10px;}
.mk p{font-size:.84rem;color:var(--t2);line-height:1.8;}
.mk-ico{font-size:2.2rem;margin-bottom:14px;}

/* ===== SMART AGRI ===== */
#agri{background:#eef8fb;}
.agri-wrap{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;}
.agri-vis{border-radius:var(--r2);background:linear-gradient(145deg,#e0f5e0,#c8efc8);border:1px solid rgba(22,163,74,.15);padding:40px;display:flex;flex-direction:column;gap:16px;box-shadow:var(--shd);}
.agri-card{background:rgba(255,255,255,.92);border:1px solid rgba(22,163,74,.15);border-radius:var(--r);padding:16px 20px;display:flex;align-items:center;gap:14px;}
.agri-card-ico{width:40px;height:40px;min-width:40px;border-radius:9px;background:rgba(22,163,74,.1);border:1px solid rgba(22,163,74,.2);display:flex;align-items:center;justify-content:center;font-size:1rem;}
.agri-card-tt{font-size:.88rem;font-weight:900;color:var(--navy);}
.agri-card-ds{font-size:.78rem;color:var(--t2);margin-top:2px;}
.agri-tag{color:#16a34a;}.agri-tag::before{background:#16a34a;}
.agri-vals{display:flex;flex-direction:column;gap:12px;margin:24px 0 32px;}
.av{display:flex;align-items:flex-start;gap:13px;background:#fff;border:1px solid var(--bdr);border-radius:var(--r);padding:16px 18px;transition:all .25s;}
.av:hover{border-color:var(--blue-line);background:#eef8fb;transform:translateX(4px);}
.av-ic{width:36px;height:36px;min-width:36px;border-radius:8px;background:var(--blue-s);border:1px solid var(--blue-line);display:flex;align-items:center;justify-content:center;font-size:.9rem;}
.av-tt{font-size:.88rem;font-weight:900;color:var(--navy);margin-bottom:2px;}
.av-ds{font-size:.81rem;color:var(--t2);line-height:1.6;}

/* ===== ABOUT / SUNAO ===== */
#abt{background:#fff;}
.ab-wrap{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;}
.sunao-box{border-radius:var(--r2);background:linear-gradient(145deg,#eef8fb,#d8f0f7);border:1px solid var(--bdr);padding:36px 30px;box-shadow:var(--shd);}
.sunao-title{font-family:'Rajdhani',sans-serif;font-size:2.6rem;font-weight:700;color:var(--blue);letter-spacing:.06em;margin-bottom:4px;}
.sunao-sub{font-size:.78rem;color:var(--t3);letter-spacing:.1em;margin-bottom:28px;}
.sunao-rows{display:flex;flex-direction:column;}
.sr{display:flex;align-items:stretch;border-bottom:1px solid var(--bdr);}
.sr:last-child{border-bottom:none;}
.sr-letter{font-family:'Rajdhani',sans-serif;font-size:2.8rem;font-weight:700;color:var(--blue);width:56px;min-width:56px;display:flex;align-items:center;justify-content:center;background:rgba(0,168,204,.06);border-right:1px solid var(--bdr);padding:18px 0;line-height:1;}
.sr-body{padding:16px 18px;}
.sr-en{font-family:'Rajdhani',sans-serif;font-size:.68rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--blue);margin-bottom:2px;}
.sr-ja{font-size:.88rem;font-weight:700;color:var(--navy);}
.sr-desc{font-size:.8rem;color:var(--t2);margin-top:2px;line-height:1.6;}
.ab-stat-row{display:flex;gap:12px;margin-top:20px;}
.ab-stat{flex:1;background:rgba(255,255,255,.9);border:1px solid var(--bdr);border-radius:var(--r);padding:14px 16px;text-align:center;}
.ab-stat-n{font-family:'Rajdhani',sans-serif;font-size:1.6rem;font-weight:700;color:var(--blue);line-height:1;}
.ab-stat-l{font-size:.72rem;color:var(--t3);margin-top:3px;}
.about-vals{display:flex;flex-direction:column;gap:12px;margin:24px 0 32px;}

/* ===== PRODUCTS (タイムスイッチ) ===== */
#prod{background:#eef8fb;}
.pg{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.pc{background:#fff;border:1px solid var(--bdr);border-radius:var(--r2);padding:28px 24px;transition:all .3s;cursor:pointer;}
.pc:hover{transform:translateY(-3px);box-shadow:var(--shd);border-color:var(--blue-line);}
.pc-ico{font-size:2.5rem;margin-bottom:16px;}
.pc h3{font-size:.96rem;font-weight:900;color:var(--navy);margin-bottom:8px;}
.pc p{font-size:.84rem;color:var(--t2);line-height:1.8;}
.pc-tag{display:inline-flex;font-family:'Rajdhani',sans-serif;font-size:.6rem;font-weight:700;letter-spacing:.1em;background:var(--blue-s);color:var(--blue);padding:3px 9px;border-radius:2px;margin-top:12px;border:1px solid var(--blue-line);}

/* ===== COMPANY ===== */
#company{background:#fff;}
.comp-wrap{display:grid;grid-template-columns:1fr 1fr 1fr;gap:40px;align-items:start;}
.comp-table{width:100%;border-collapse:collapse;}
.comp-table tr{border-bottom:1px solid var(--bdr);}
.comp-table tr:last-child{border-bottom:none;}
.comp-table th{font-size:.8rem;font-weight:700;color:var(--t3);padding:14px 0;width:110px;vertical-align:top;font-family:'Rajdhani',sans-serif;letter-spacing:.06em;text-transform:uppercase;}
.comp-table td{font-size:.88rem;color:var(--t1);padding:14px 0 14px 10px;line-height:1.75;}
.comp-map{border-radius:var(--r2);overflow:hidden;background:#e8f5f9;border:1px solid var(--bdr);padding:0;position:relative;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;font-size:3rem;box-shadow:var(--shd);}
.map-pin{position:absolute;bottom:20px;left:20px;right:20px;background:rgba(255,255,255,.95);border-radius:var(--r);padding:14px 16px;border:1px solid var(--bdr);}
.map-pin p{font-size:.84rem;font-weight:700;color:var(--navy);}
.map-pin span{font-size:.76rem;color:var(--t2);}

/* ===== NEWS ===== */
#nws{background:#eef8fb;}
.nl{border:1px solid var(--bdr);border-radius:var(--r2);overflow:hidden;}
.ni{display:flex;align-items:center;gap:20px;padding:18px 28px;background:#fff;border-bottom:1px solid var(--bdr);transition:background .2s;text-decoration:none;color:inherit;}
.ni:last-child{border-bottom:none;}.ni:hover{background:#eef8fb;}
.nd{font-family:'Rajdhani',sans-serif;font-size:.76rem;font-weight:600;color:var(--t3);min-width:88px;white-space:nowrap;letter-spacing:.06em;}
.nc{flex-shrink:0;font-family:'Rajdhani',sans-serif;font-size:.62rem;font-weight:700;padding:3px 10px;border-radius:2px;letter-spacing:.1em;text-transform:uppercase;}
.ci{background:rgba(0,168,204,.1);color:var(--blue);}
.cp{background:rgba(22,163,74,.1);color:#16a34a;}
.ce{background:rgba(217,119,6,.1);color:#d97706;}
.nt{font-size:.88rem;font-weight:700;color:var(--t1);flex:1;}
.ni:hover .nt{color:var(--navy);}
.na{color:var(--t3);font-family:'Rajdhani',sans-serif;transition:all .2s;}
.ni:hover .na{color:var(--blue);transform:translateX(4px);}

/* ===== CONTACT ===== */
#ctc{background:#fff;}
.ctc-hd{text-align:center;margin-bottom:56px;}
.ctc-hd .sec-sub{margin:0 auto;}
.ctc-wrap{display:flex;justify-content:center;}
.ccards{display:flex;flex-direction:column;gap:10px;margin-bottom:24px;}
.ccard{background:#eef8fb;border:1px solid var(--bdr);border-radius:var(--r);padding:15px 20px;display:flex;align-items:center;gap:13px;transition:all .25s;}
.ccard:hover{border-color:var(--blue-line);background:#dff0f7;transform:translateX(3px);}
.cico{width:40px;height:40px;min-width:40px;border-radius:var(--r);background:var(--blue-s);border:1px solid var(--blue-line);display:flex;align-items:center;justify-content:center;font-size:1rem;}
.clbl{font-family:'Rajdhani',sans-serif;font-size:.6rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--t3);margin-bottom:1px;}
.cval{font-size:.86rem;font-weight:700;color:var(--t1);}
.cfb{background:#fff;border:1px solid var(--bdr);border-radius:var(--r2);padding:40px 48px;box-shadow:var(--shd);width:100%;max-width:680px;}
.fttl{font-size:1rem;font-weight:900;color:var(--navy);margin-bottom:22px;display:flex;align-items:center;gap:8px;}
.fttl::before{content:'';width:3px;height:1em;background:var(--blue);border-radius:2px;}
.fg{margin-bottom:14px;}
.flbl{display:block;font-family:'Rajdhani',sans-serif;font-size:.64rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--t2);margin-bottom:6px;}
.req{color:var(--blue);margin-left:2px;}
.fi,.fsl,.fta{width:100%;background:#eef8fb;border:1px solid var(--bdr);border-radius:var(--r);padding:11px 14px;color:var(--t1);font-family:'Zen Kaku Gothic New',sans-serif;font-size:.87rem;outline:none;transition:all .25s;}
.fi:focus,.fsl:focus,.fta:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(0,168,204,.08);}
.fi::placeholder,.fta::placeholder{color:var(--t3);}
.fsl{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234a5a78' stroke-width='1.5' stroke-linecap='round' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;background-color:#eef8fb;}
.fsl option{background:#fff;}
.fta{resize:vertical;min-height:100px;}
.fr2{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.bsub{width:100%;background:var(--blue);color:#fff;border:none;border-radius:4px;padding:14px;font-family:'Zen Kaku Gothic New',sans-serif;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .25s var(--bounce);box-shadow:var(--sh);margin-top:4px;letter-spacing:.04em;}
.bsub:hover{background:var(--blue-l);transform:translateY(-2px);box-shadow:0 10px 36px rgba(0,168,204,.28);}

/* ===== FOOTER ===== */
footer{background:#0d1829;border-top:1px solid rgba(255,255,255,.06);padding:60px 0 30px;}
.ft{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:48px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.07);margin-bottom:24px;}
.flogo-mark{display:inline-flex;align-items:center;gap:8px;margin-bottom:12px;}
.flogo-mark svg{height:32px;width:auto;}
.fdesc{font-size:.8rem;color:rgba(255,255,255,.32);line-height:1.85;max-width:230px;margin-bottom:0;}
.fcat{font-family:'Rajdhani',sans-serif;font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.32);margin-bottom:14px;}
.fls{display:flex;flex-direction:column;gap:9px;}
.fls a{font-size:.8rem;color:rgba(255,255,255,.28);transition:color .2s;}.fls a:hover{color:rgba(255,255,255,.65);}
.fbot{display:flex;align-items:center;justify-content:space-between;font-size:.74rem;color:rgba(255,255,255,.22);}
.fbot-r a{color:rgba(255,255,255,.22);transition:color .2s;}.fbot-r a:hover{color:rgba(255,255,255,.5);}

/* ===== HAMBURGER MENU ===== */
.nav-contact-btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Zen Kaku Gothic New',sans-serif;font-weight:700;font-size:.76rem;
  border-radius:4px;padding:8px 18px;
  background:var(--blue);color:#fff;box-shadow:var(--sh);
  text-decoration:none;flex-shrink:0;
  transition:all .25s var(--bounce);letter-spacing:.04em;
  white-space:nowrap;
}
.nav-contact-btn:hover{background:var(--blue-l);transform:translateY(-1px);}
.nav-contact-icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--r);background:var(--blue);color:#fff;box-shadow:var(--sh);text-decoration:none;flex-shrink:0;transition:all .25s var(--bounce);}
.nav-contact-icon:hover{background:var(--blue-l);transform:translateY(-1px);}
.nav-contact-icon svg{width:20px;height:20px;}
.hamburger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:40px;height:40px;border:none;background:transparent;cursor:pointer;padding:4px;border-radius:var(--r);transition:background .2s;flex-shrink:0;}
.hamburger:hover{background:var(--blue-s);}
.hamburger span{display:block;width:22px;height:2.5px;background:var(--navy);border-radius:2px;transition:all .3s var(--ease);transform-origin:center;}
.hamburger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.hamburger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}
/* ドロップダウンメニュー */
.nav-dropdown{
  display:none;position:fixed;left:0;right:0;
  background:rgba(255,255,255,.98);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-top:2px solid var(--blue);border-bottom:1px solid var(--bdr);
  box-shadow:0 8px 32px rgba(13,24,41,.1);
  z-index:499;
  padding:8px 0;
  max-height:calc(100vh - 54px);
  overflow-y:auto;
}
.nav-dropdown.open{display:block;}
.nav-dropdown a{
  display:flex;align-items:center;gap:12px;
  padding:14px clamp(16px,4vw,64px);
  font-family:'Rajdhani',sans-serif;font-size:.9rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--t2);transition:all .2s;border-bottom:1px solid var(--bdr);
}
.nav-dropdown a:last-child{border-bottom:none;}
.nav-dropdown a::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--blue);opacity:.4;flex-shrink:0;transition:opacity .2s;}
.nav-dropdown a:hover{color:var(--blue);background:var(--blue-s);}
.nav-dropdown a:hover::before{opacity:1;}

/* ===== SP NEWS BOX（ヒーロー下・事業内容上に表示）===== */
#sp-news{display:none;margin:0;padding:20px 0;}
#sp-news .container{padding:0 clamp(16px,4vw,32px);}

@media(max-width:900px){
  .nav-links{display:none !important;}
  .hamburger{display:flex;}
  #nav-ctc-pc{display:none !important;}
  #nav-ctc-sp{display:inline-flex !important;}
}
@media(min-width:901px){
  .hamburger{display:none;}
  .nav-dropdown{display:none !important;}
  #nav-ctc-sp{display:none !important;}
  #nav-ctc-pc{display:inline-flex !important;}
}
/* ヒーローお知らせ：1024px以下で非表示 → SP NEWSに表示 */
@media(max-width:1024px){
  .hero-in{grid-template-columns:1fr;}
  .h-vis{display:none !important;}
  #sp-news{display:block;}
  .ab-wrap,.comp-wrap,.ctc-wrap{grid-template-columns:1fr;}
  .sg{grid-template-columns:1fr 1fr;}
  .maker-grid{grid-template-columns:1fr 1fr;}
  .pg{grid-template-columns:1fr 1fr;}
  .ft{grid-template-columns:1fr 1fr;gap:28px;}
  #ticker{display:none;}
  /* agri SP: 文章→ビジュアルの順 */
  .agri-wrap{grid-template-columns:1fr !important;}
  .agri-txt-col{order:1;}
  .agri-vis-col{order:2;}
}
@media(max-width:768px){
  .nav-links{display:none;}
  .sg,.fr2{grid-template-columns:1fr;}
  .maker-grid{grid-template-columns:1fr 1fr;}
  .pg{grid-template-columns:1fr 1fr;}
  .ft{grid-template-columns:1fr;}
  .fbot{flex-direction:column;gap:8px;text-align:center;}
  .h-stats{flex-wrap:wrap;gap:16px;}.hst{flex:0 0 calc(50% - 8px);border-right:none;margin:0;padding:0;}
  .sec-row{flex-direction:column;align-items:flex-start;}
  .cfb{padding:22px 18px;}
  .ab-wrap{grid-template-columns:1fr;}
}
@media(max-width:480px){
  .h1{font-size:2.1rem;}
  .h-acts{flex-direction:column;}
  .h-acts .btn{width:100%;justify-content:center;}
  .ni{flex-wrap:wrap;gap:10px;padding:14px 16px;}
  .nd{min-width:auto;}
  .comp-table th{width:86px;font-size:.74rem;}
  .cfb{padding:18px 14px;}
  .sunao-box{padding:24px 18px;}
  .sr-letter{width:46px;min-width:46px;font-size:2.2rem;}
  .maker-grid,.pg{grid-template-columns:1fr;}
}
@media(max-width:390px){
  .container{padding:0 14px;}
  .h1{font-size:1.9rem;}
  .sec-title{font-size:1.5rem;}
  .logo svg{height:28px;}
}
