*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN',sans-serif;color:#222;background:#fff;-webkit-font-smoothing:antialiased;margin:0;max-width:100%;overflow-x:hidden}
html.menu-open,body.menu-open{overflow:hidden;overscroll-behavior:none}
a{text-decoration:none;color:inherit}
ul,ol{list-style:none;margin:0;padding:0}

/* ===== HEADER ===== */
:root{
    --header-max-width:1310px;
    --header-gutter:20px;
}

#site-header{
    position:sticky;
    top:0;
    z-index:500;
    isolation:isolate;
    transition:box-shadow .3s;
    border-bottom:1px solid #ececec;
    background:#fff;
}
#site-header.scrolled{box-shadow:0 2px 16px rgba(0,0,0,.12)}
#nav-bar{position:relative;background:#fff}
#nav-inner{position:relative;z-index:260}
#nav-inner>a{display:flex;align-items:center}

/* ===== TOP BAR ===== */
.hbar-lnk{font-size:11px;color:#888;text-decoration:none;transition:color .15s}
.hbar-lnk:hover{color:#fff}

/* ===== NAV LINKS ===== */
.hn-link{
    display:inline-flex;align-items:center;
    padding:0 18px;color:#444;text-decoration:none;font-size:15px;font-weight:500;
    height:100%;position:relative;transition:color .15s;white-space:nowrap;
}
.hn-link::after{
    content:'';
    position:absolute;bottom:0;left:18px;right:18px;
    height:3px;background:#e30613;transform:scaleX(0);transition:transform .2s;
}
.hn-link:hover{color:#e30613}
.hn-link:hover::after,.hn-item.open>.hn-link::after{transform:scaleX(1)}
.hn-link.hn-current{color:#e30613}
.hn-link.hn-current::after{transform:scaleX(1)}
.hn-item.open>.hn-link{color:#e30613}
.hn-chevron{display:none}
.hn-item.open>.hn-link .hn-chevron{transform:rotate(180deg)}

.desktop-actions{
    display:flex;
    align-items:center;
    gap:14px;
    margin-left:14px;
}
.hd-icon{
    width:24px;
    height:24px;
    padding:0;
    border:none;
    background:transparent;
    color:#2f2f2f;
    display:flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
    transition:color .15s;
}
.hd-icon:hover{color:#e30613}
#mobile-btn{
    position:relative;
    width:32px;
    height:32px;
    padding:0;
    border:none;
    background:transparent;
    color:#333;
}
.mobile-btn-icon{
    position:absolute;
    inset:0;
    display:flex;
    align-items:center;
    justify-content:center;
    transition:opacity .22s ease,transform .22s ease;
}
.mobile-btn-icon-close{
    opacity:0;
    transform:rotate(-90deg) scale(.85);
}
#mobile-btn[aria-expanded="true"] .mobile-btn-icon-menu{
    opacity:0;
    transform:rotate(90deg) scale(.85);
}
#mobile-btn[aria-expanded="true"] .mobile-btn-icon-close{
    opacity:1;
    transform:rotate(0deg) scale(1);
}

/* ===== MEGA PANEL (full-width, two-panel) ===== */
.mega-panel{
    position:absolute;top:100%;left:0;right:0;width:100%;
    background:#fff;
    border-top:1px solid #ececec;
    border-bottom:1px solid #ececec;
    box-shadow:0 16px 36px rgba(0,0,0,.08);
    opacity:0;visibility:hidden;transform:translateY(-4px);
    transition:opacity .22s,visibility .22s,transform .22s;
    z-index:220;
}
.mega-panel.open{opacity:1;visibility:visible;transform:translateY(0)}
.mega-panel-dropdown{
    left:var(--drop-left,50%);
    right:auto;
    width:var(--drop-width,220px);
    border:1px solid #dfdfdf;
    border-top:none;
    box-shadow:0 12px 24px rgba(0,0,0,.14);
    transform:translate(-50%,-4px);
    z-index:245;
}
.mega-panel-dropdown.open{transform:translate(-50%,0)}
.mega-dropdown-inner{padding:6px 0;background:#fff}
.mega-dd-link{
    display:block;
    padding:10px 16px;
    font-size:14px;
    color:#4f4f4f;
    line-height:1.35;
    text-align:center;
    white-space:nowrap;
    transition:color .15s,background .15s;
}
.mega-dd-link:hover{
    color:#e30613;
    background:#f8f8f8;
}
.mega-panel-inner{
    max-width:var(--header-max-width);
    margin:0 auto;
    padding:0 var(--header-gutter);
}

/* Two-panel layout */
.mega-body{
    display:flex;
    min-height:350px;
    max-height:calc(100vh - 110px);
    overflow:hidden;
}

/* Left sidebar */
.mega-sidebar{
    width:272px;
    flex-shrink:0;
    background:#f7f7f7;border-right:1px solid #ebebeb;
    padding:18px 0;
    overflow-y:auto;
}
.mega-sidebar ul{list-style:none;padding:0;margin:0}
.mega-sitem a{
    display:block;padding:10px 26px 10px 28px;
    font-size:14px;color:#555;text-decoration:none;
    border-left:3px solid transparent;
    transition:color .15s,border-color .15s,background .15s;
    line-height:1.45;
}
.mega-sitem.active>a,.mega-sitem:hover>a{
    color:#e30613;border-left-color:#e30613;
    background:#fff;font-weight:500;
}

/* Right content */
.mega-content{
    flex:1;
    padding:24px 28px 30px;
    overflow-y:auto;
}
.mega-sub{display:none}
.mega-sub.active{display:block}

/* Product grid */
.mega-prod-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(158px,158px));
    gap:18px 16px;
    justify-content:flex-start;
}
.mega-prod-card{width:auto;min-width:0}
.mega-prod-h{
    font-size:14px;
    font-weight:700;
    color:#111;
    margin-bottom:10px;
    line-height:1.35;
    min-height:var(--mega-title-height,0px);
}
.mega-prod-img{
    background:#f2f2f2;height:112px;
    display:flex;align-items:center;justify-content:center;
    overflow:hidden;margin-bottom:9px;
}
.mega-prod-img img{max-width:90%;max-height:96px;object-fit:contain;transition:transform .3s}
.mega-prod-card:hover .mega-prod-img img{transform:scale(1.05)}
.mega-prod-list{list-style:none;padding:0;margin:0}
.mega-prod-list li a{
    display:block;font-size:12px;color:#555;padding:2px 0;
    text-decoration:none;transition:color .15s;line-height:1.5;
}
.mega-prod-list li a:hover{color:#e30613}
.prod-new{
    display:inline-block;font-size:10px;font-weight:700;color:#e30613;
    font-style:italic;margin-left:2px;
}

/* ===== MOBILE MENU ===== */
#mobile-menu{
    display:none;
    background:#fff;
}
#mobile-menu.open{display:block}
.mobile-menu-stage{
    position:relative;
    height:100%;
    overflow:hidden;
    background:#fff;
}
.mobile-main-list{
    height:100%;
    margin:0;
    padding:0 16px;
    list-style:none;
    overflow:auto;
    -ms-scroll-chaining:none;
    overscroll-behavior:contain;
    -webkit-overflow-scrolling:touch;
}
.mobile-main-item{margin:0}
.mobile-main-btn,
.mobile-main-link{
    width:100%;
    min-height:48px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    border:none;
    border-bottom:1px solid #eaeaea;
    background:#fff;
    padding:16px 0;
    color:#333;
    font-size:14px;
    font-weight:600;
    line-height:1.45;
    text-decoration:none;
    text-align:left;
}
.mobile-main-btn{cursor:pointer}
.mobile-main-text{display:block;flex:1}
.mobile-main-arrow{
    width:8px;
    height:8px;
    margin-right:2px;
    border-top:1.5px solid #333;
    border-right:1.5px solid #333;
    transform:rotate(45deg);
    flex-shrink:0;
}
.mobile-sub-panel{
    position:absolute;
    inset:0;
    background:#fff;
    transform:translateX(100%);
    transition:transform .28s ease;
    display:flex;
    flex-direction:column;
    z-index:3;
}
.mobile-sub-panel.open{transform:translateX(0)}
.mobile-sub-header{
    height:48px;
    display:flex;
    align-items:center;
    justify-content:flex-start;
    gap:8px;
    padding:0 16px;
    border-bottom:1px solid #d8d8d8;
    background:#f7f7f7;
}
.mobile-sub-back{
    border:none;
    background:none;
    padding:0;
    color:#333;
    font-size:14px;
    line-height:1;
    cursor:pointer;
    display:inline-flex;
    align-items:center;
    gap:6px;
}
.mobile-sub-back::before{
    content:'';
    width:8px;
    height:8px;
    border-top:1.5px solid #333;
    border-right:1.5px solid #333;
    transform:rotate(-135deg);
}
.mobile-sub-title{
    font-size:14px;
    color:#333;
    font-weight:500;
    line-height:1.4;
}
.mobile-sub-body{
    flex:1;
    overflow:auto;
    padding:0 16px 16px;
    -ms-scroll-chaining:none;
    overscroll-behavior:contain;
    -webkit-overflow-scrolling:touch;
}
.mob-sub{padding:0;display:flex;flex-direction:column;gap:0}
.mob-sub a{
    display:block;
    font-size:14px;
    color:#333;
    line-height:1.5;
    padding:14px 0;
    border-bottom:1px solid #eaeaea;
    text-decoration:none;
}
.mob-sub a:hover{color:#333}
.mob-cat{
    display:block;
    margin:8px 0 0;
    padding:10px 0 6px;
    font-size:13px;
    line-height:1.4;
    color:#333;
    font-weight:600;
}
.mob-l1{
    border-bottom:1px solid #dcdcdc;
}
.mob-l1-sum{
    list-style:none;
    display:flex;
    align-items:center;
    justify-content:space-between;
    width:100%;
    padding:14px 0;
    color:#333;
    font-size:15px;
    font-weight:500;
    line-height:1.45;
    cursor:pointer;
}
.mob-l1-sum::-webkit-details-marker{display:none}
.mob-l1-sum::after{
    content:'';
    width:8px;
    height:8px;
    border-top:1.5px solid #333;
    border-right:1.5px solid #333;
    transform:rotate(135deg);
    transition:transform .2s;
    margin-right:2px;
    flex-shrink:0;
}
.mob-l1[open]>.mob-l1-sum::after{transform:rotate(-45deg)}
.mob-l1-body{
    padding:0 0 2px 10px;
    margin-left:8px;
    border-left:1px solid #e5e5e5;
}

.mob-l2{
    border-top:1px solid #e8e8e8;
}
.mob-l2:first-child{border-top:none}
.mob-l2-sum{
    list-style:none;
    display:flex;
    align-items:center;
    justify-content:space-between;
    width:100%;
    padding:14px 0 14px 6px;
    color:#333;
    font-size:14px;
    font-weight:400;
    line-height:1.45;
    cursor:pointer;
}
.mob-l2-sum::-webkit-details-marker{display:none}
.mob-l2-sum::after{
    content:'';
    width:7px;
    height:7px;
    border-top:1.5px solid #555;
    border-right:1.5px solid #555;
    transform:rotate(135deg);
    transition:transform .2s;
    margin-right:2px;
    flex-shrink:0;
}
.mob-l2[open]>.mob-l2-sum::after{transform:rotate(-45deg)}
.mob-l2-body{
    padding:0 0 12px 6px;
}
.mob-prod-strip{
    display:flex;
    gap:10px;
    overflow-x:auto;
    padding:2px 0 4px;
    -webkit-overflow-scrolling:touch;
}
.mob-prod-strip::-webkit-scrollbar{display:none}
.mob-sub .mob-prod-chip{
    width:102px;
    flex:0 0 102px;
    display:block;
    text-decoration:none;
    border:none;
    border-bottom:none;
    padding:0;
    line-height:1.2;
}
.mob-sub .mob-prod-chip:hover{color:#333}
.mob-sub .mob-prod-chip-img{
    position:relative;
    width:100%;
    aspect-ratio:1 / 1;
    height:auto;
    background:#f2f2f2;
    display:flex;
    align-items:center;
    justify-content:center;
}
.mob-sub .mob-prod-chip-img img{
    max-width:82%;
    max-height:82%;
    object-fit:contain;
}
.mob-sub .mob-prod-chip-new{
    position:absolute;
    top:4px;
    left:6px;
    font-size:11px;
    line-height:1;
    color:#d8000f;
    font-style:italic;
    font-weight:700;
}
.mob-sub .mob-prod-chip-name{
    display:block;
    margin-top:8px;
    font-size:12px;
    color:#333;
    line-height:1.35;
    text-align:center;
}
.mob-sub-generated{gap:0}
.mob-nest{border-bottom:1px solid #eaeaea}
.mob-nest:first-child{border-top:none}
.mob-nest-sum{
    list-style:none;
    display:flex;
    align-items:center;
    justify-content:space-between;
    width:100%;
    padding:16px 0;
    color:#333;
    font-size:14px;
    font-weight:600;
    line-height:1.45;
    cursor:pointer;
}
.mob-nest-sum::-webkit-details-marker{display:none}
.mob-nest-sum::after{
    content:'';
    width:8px;
    height:8px;
    margin-right:2px;
    border-top:1.5px solid #333;
    border-right:1.5px solid #333;
    transform:rotate(45deg);
    transition:transform .2s;
    flex-shrink:0;
}
.mob-nest[open]>.mob-nest-sum::after{transform:rotate(135deg)}
.mob-nest-body{
    padding:0 0 6px 16px;
    display:flex;
    flex-direction:column;
}
.mob-nest-body .mob-cat{margin-top:0}

/* ===== HERO ===== */
#hero{height:620px;position:relative;overflow:hidden;background:#111}
@media(min-width:1024px){#hero{height:740px}}
.slide{position:absolute;inset:0;opacity:0;transition:opacity .9s cubic-bezier(.4,0,.2,1);pointer-events:none}
.slide.active{opacity:1;pointer-events:auto}
.slide-bg{width:100%;height:100%;object-fit:cover;object-position:center;transform:scale(1.05);transition:transform 7s ease}
.slide.active .slide-bg{transform:scale(1)}
.slide-ov{position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.72) 0%,rgba(0,0,0,.28) 55%,transparent 100%)}
.slide-ct{position:absolute;inset:0;display:flex;align-items:center}
.hero-text{opacity:0;transform:translateY(24px);transition:opacity .7s ease .35s,transform .7s ease .35s}
.slide.active .hero-text{opacity:1;transform:translateY(0)}
.hero-tag{display:inline-block;font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:#e30613;font-weight:600;margin-bottom:12px}
.hero-h2{font-size:clamp(24px,4vw,48px);font-weight:700;color:#fff;line-height:1.25;margin:0 0 16px}
.hero-p{font-size:15px;color:rgba(255,255,255,.8);line-height:1.75;margin:0 0 28px;max-width:440px}
.hero-btn{display:inline-block;background:#e30613;color:#fff;font-size:13px;font-weight:500;padding:13px 30px;letter-spacing:.05em;transition:background .2s,transform .2s}
.hero-btn:hover{background:#c0000f;transform:translateY(-1px)}
.c-arrow{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.2);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,border-color .2s;z-index:10;-webkit-appearance:none;appearance:none}
.c-arrow:hover{background:rgba(227,6,19,.8);border-color:#e30613}
#prev-slide{left:20px}
#next-slide{right:20px}
.c-dots{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:10}
.dot{
    width:28px;
    height:3px;
    border:none;
    padding:0;
    cursor:pointer;
    background:rgba(255,255,255,.3);
    position:relative;
    overflow:hidden;
    transition:background .3s,width .3s;
}
.dot::after{
    content:'';
    position:absolute;
    top:0;
    left:0;
    height:100%;
    width:0;
    background:#fff;
}
.dot.active{background:rgba(255,255,255,.48);width:40px}
.dot.active.progress::after{
    animation:hero-dot-progress var(--hero-progress-duration,5500ms) linear forwards;
}
@keyframes hero-dot-progress{
    from{width:0}
    to{width:100%}
}

/* ===== TABS ===== */
.tab-bar{border-bottom:1px solid #e5e5e5;display:flex;overflow-x:auto;scrollbar-width:none}
.tab-bar::-webkit-scrollbar{display:none}
.tab-btn{flex-shrink:0;padding:14px 22px;font-size:13px;font-weight:500;color:#666;border:none;border-bottom:3px solid transparent;cursor:pointer;white-space:nowrap;transition:color .2s,border-color .2s;background:none;font-family:inherit}
.tab-btn:hover{color:#e30613}
.tab-btn.active{color:#e30613;border-bottom-color:#e30613}
.tab-panel{display:none}
.tab-panel.active{display:block;animation:fadeUp .35s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

.products-section{
    background:#efefef;
    padding:24px 0 60px;
}
.products-inner{max-width:1280px;margin:0 auto;padding:0 24px}
.lineup-tabs{border-bottom:none;justify-content:center;gap:34px;padding:2px 0 10px}
.lineup-tabs .tab-btn{padding:10px 16px;min-height:40px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;letter-spacing:.02em;border:none;border-radius:999px;color:#1f2937}
.lineup-tabs .tab-btn.active{background:#e30613;color:#fff;border-radius:999px;padding:10px 22px}
.lineup-tabs .tab-btn:hover{color:#e30613}
.lineup-tabs .tab-btn.active:hover{color:#fff}

/* ===== PRODUCT CARDS ===== */
.prod-card{border:1px solid #ebebeb;background:#fff;text-align:center;display:block;transition:border-color .22s,box-shadow .22s,transform .22s;overflow:hidden;cursor:pointer}
.prod-card:hover{border-color:#e30613;box-shadow:0 4px 18px rgba(227,6,19,.1);transform:translateY(-3px)}
.pc-img{background:#f8f8f8;height:140px;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:12px}
.pc-img img{max-height:110px;max-width:100%;object-fit:contain;transition:transform .4s ease}
.prod-card:hover .pc-img img{transform:scale(1.07)}
.pc-body{padding:10px 10px 14px}
.pc-name{font-size:12px;font-weight:600;color:#222;line-height:1.4;margin:0}
.pc-sub{font-size:11px;color:#888;margin:3px 0 0;line-height:1.4}
.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:12px}

/* ===== LINEUP CARDS ===== */
.lineup-grid{display:grid;gap:16px}
.lineup-grid-1{grid-template-columns:1fr}
.lineup-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.lineup-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.lineup-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.lineup-card{border:1px solid #ebebeb;background:#fff;display:flex;flex-direction:column;overflow:hidden;transition:border-color .22s,box-shadow .22s,transform .22s}
.lineup-card:hover{border-color:#e30613;box-shadow:0 6px 20px rgba(0,0,0,.08);transform:translateY(-2px)}
.lineup-card-wide{grid-column:span 2}
.lineup-img{width:100%;height:220px;object-fit:cover;display:block;background:#f5f5f5}
.lineup-body{padding:18px 18px 20px}
.lineup-title{font-size:18px;font-weight:700;color:#111;line-height:1.35;margin:0 0 8px}
.lineup-desc{font-size:13px;color:#666;line-height:1.7;margin:0}
.lineup-links{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.lineup-chip{display:inline-flex;align-items:center;min-height:28px;padding:5px 10px;border:1px solid #e2e2e2;background:#fafafa;font-size:12px;color:#444;line-height:1.3;transition:border-color .15s,color .15s,background .15s}
.lineup-chip:hover{border-color:#e30613;color:#e30613;background:#fff}

/* ===== HANDHELD HERO LAYOUT ===== */
.lineup-anchor{position:absolute;top:-76px}
.lineup-handheld-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.lineup-hero-grid-1{display:grid;grid-template-columns:1fr;gap:16px}
.lineup-hero-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.lineup-instru-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.lineup-instru-grid .lineup-hero-card-fire{grid-column:1/-1}
.lineup-hero-card{position:relative;min-height:352px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;color:#fff;background:transparent}
.lineup-hero-card-fire{grid-column:1/-1;min-height:312px}
.lineup-hero-card-fixed{min-height:378px}
.lineup-hero-card-software{min-height:334px}
.lineup-hero-card-fixed .lineup-hero-content{max-width:56%}
.lineup-hero-card-software .lineup-hero-content{max-width:74%}
.lineup-hero-bg{position:absolute;top:-1px;left:-1px;width:calc(100% + 2px);height:calc(100% + 2px);object-fit:cover;object-position:center;display:block}
.lineup-hero-ov{position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,16,26,.58) 0%,rgba(10,16,26,.28) 58%,rgba(10,16,26,.08) 100%)}
.lineup-hero-ov-fire{background:linear-gradient(90deg,rgba(5,11,22,.76) 0%,rgba(5,11,22,.32) 58%,rgba(5,11,22,.12) 100%)}
.lineup-hero-content{position:relative;z-index:2;max-width:70%;padding:28px 36px 6px}
.lineup-hero-content h3{margin:0 0 10px;font-size:32px;line-height:1.2;font-weight:700;color:#fff}
.lineup-hero-content p{margin:0;font-size:15px;line-height:1.55;color:rgba(255,255,255,.92)}
.lineup-hero-picks{position:relative;z-index:2;display:flex;align-items:stretch;gap:10px;padding:0 36px 20px}
.lineup-hero-pick{width:126px;min-height:114px;border:1px solid rgba(255,255,255,.42);background:rgba(255,255,255,.10);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 8px;color:#fff;transition:background .2s,border-color .2s}
.lineup-hero-pick:hover{background:rgba(227,6,19,.23);border-color:rgba(255,255,255,.75)}
.lineup-hero-pick img{max-width:74px;max-height:62px;object-fit:contain;margin-bottom:8px}
.lineup-hero-pick span{font-size:12px;line-height:1.35;font-weight:600;text-align:center}
.lineup-hero-next{width:34px;min-height:114px;border:1px solid rgba(255,255,255,.42);background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;line-height:1;transition:background .2s,border-color .2s}
.lineup-hero-next:hover{background:rgba(227,6,19,.23);border-color:rgba(255,255,255,.75)}

.lineup-gallery-wrap{position:relative;z-index:2;display:flex;align-items:stretch;gap:8px;padding:0 36px 20px;min-width:0}
.lineup-gallery{flex:1;min-width:0;overflow-x:auto;scroll-behavior:smooth;scrollbar-width:none}
.lineup-gallery::-webkit-scrollbar{display:none}
.lineup-gallery-track{display:flex;gap:10px;min-width:max-content}
.lineup-gallery-btn{width:34px;min-height:114px;border:1px solid rgba(255,255,255,.42);background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;line-height:1;cursor:pointer;transition:background .2s,border-color .2s}
.lineup-gallery-btn:hover{background:rgba(227,6,19,.23);border-color:rgba(255,255,255,.75)}

/* ===== SERIES HEADER ===== */
.sh{display:flex;align-items:baseline;gap:10px;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid #f0f0f0}
.sh h3{font-size:16px;font-weight:700;color:#111;margin:0}
.sh span{font-size:12px;color:#999}
.sdesc{font-size:12px;color:#888;margin:0 0 16px;line-height:1.7}

/* ===== SOFTWARE CARDS ===== */
.sw-card{display:flex;align-items:center;gap:16px;padding:18px 20px;border:1px solid #ebebeb;transition:border-color .22s,box-shadow .22s,transform .22s}
.sw-card:hover{border-color:#e30613;box-shadow:0 4px 14px rgba(227,6,19,.08);transform:translateY(-2px)}
.sw-card img{width:52px;height:52px;object-fit:contain;flex-shrink:0}
.sw-title{font-size:13px;font-weight:600;color:#222;margin:0}
.sw-sub{font-size:11px;color:#888;margin:3px 0 0}

/* ===== SPEC BOX ===== */
.spec-box{border:1px solid rgba(255,255,255,.12);padding:16px;text-align:center;background:rgba(255,255,255,.04);transition:background .2s,border-color .2s}
.spec-box:hover{background:rgba(227,6,19,.08);border-color:rgba(227,6,19,.4)}
.spec-val{font-size:22px;font-weight:700;color:#e30613;line-height:1.2;margin:0}
.spec-lbl{font-size:11px;color:rgba(255,255,255,.5);margin:4px 0 0}

/* ===== BLOG CARDS ===== */
.blog-card{border:1px solid #ebebeb;overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .25s,transform .25s}
.blog-card:hover{box-shadow:0 6px 24px rgba(0,0,0,.1);transform:translateY(-4px)}
.bc-thumb{height:200px;overflow:hidden}
.bc-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.blog-card:hover .bc-thumb img{transform:scale(1.06)}
.bc-body{padding:20px;flex:1;display:flex;flex-direction:column}
.bc-cat{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#e30613;margin-bottom:8px}
.bc-title{font-size:14px;font-weight:700;line-height:1.55;color:#111;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.blog-card:hover .bc-title{color:#e30613}
.bc-ex{font-size:12px;color:#666;line-height:1.7;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex:1}
.bc-more{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:#e30613;margin-top:14px;transition:gap .2s}
.blog-card:hover .bc-more{gap:8px}

/* ===== FEATURE CHECKS ===== */
.fcheck{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px}

/* ===== SCROLL REVEAL ===== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ===== FOOTER ===== */
.hm-footer{background:#111;color:#9a9a9a}
.hm-footer-inner{max-width:1280px;margin:0 auto;padding:42px 24px 22px}

.hmf-main{
    display:grid;
    grid-template-columns:minmax(0,1fr) 318px;
    gap:30px;
    padding-bottom:30px;
    border-bottom:1px solid #282828;
}
.hmf-links{
    display:grid;
    grid-template-columns:repeat(5,minmax(0,1fr));
    gap:20px;
}
.hmf-col h4{
    margin:0 0 13px;
    font-size:12px;
    line-height:1.4;
    font-weight:700;
    letter-spacing:.08em;
    text-transform:uppercase;
    color:#fff;
}
.fl{display:block;font-size:12px;color:#9a9a9a;padding:4px 0;line-height:1.45;transition:color .15s}
.fl:hover{color:#fff}

.hmf-subscribe{
    border:1px solid #2a2a2a;
    background:#171717;
    padding:20px;
}
.hmf-subscribe-cap{
    margin:0 0 6px;
    font-size:11px;
    color:#a0a0a0;
    letter-spacing:.08em;
    text-transform:uppercase;
}
.hmf-subscribe h4{
    margin:0 0 10px;
    font-size:24px;
    font-weight:700;
    line-height:1.2;
    color:#fff;
}
.hmf-subscribe-text{
    margin:0;
    font-size:13px;
    color:#979797;
    line-height:1.7;
}
.hmf-subscribe-actions{
    margin-top:18px;
    display:grid;
    gap:8px;
}
.hmf-btn-main,
.hmf-btn-sub{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:40px;
    padding:0 14px;
    border:1px solid transparent;
    font-size:12px;
    font-weight:600;
    transition:background .15s,color .15s,border-color .15s;
}
.hmf-btn-main{
    background:#e30613;
    border-color:#e30613;
    color:#fff;
}
.hmf-btn-main:hover{background:#c90011;border-color:#c90011}
.hmf-btn-sub{
    border-color:#373737;
    background:#1a1a1a;
    color:#d3d3d3;
}
.hmf-btn-sub:hover{border-color:#e30613;color:#fff}
.hmf-subscribe-note{
    margin:12px 0 0;
    font-size:11px;
    color:#7f7f7f;
    line-height:1.6;
}
.hmf-subscribe-note a{color:#aaa;text-decoration:underline}
.hmf-subscribe-note a:hover{color:#fff}

.hmf-bottom{
    display:grid;
    grid-template-columns:auto auto 1fr;
    align-items:center;
    gap:14px 20px;
    padding:20px 0 8px;
}
.hmf-logo{display:flex;align-items:center}
.hmf-logo img{width:auto;height:24px;filter:brightness(0) invert(1)}
.hmf-social{display:flex;align-items:center;gap:10px}
.soc-icon{
    width:34px;
    height:34px;
    border:1px solid #333;
    display:flex;
    align-items:center;
    justify-content:center;
    color:#aaa;
    transition:border-color .2s,color .2s;
}
.soc-icon:hover{border-color:#e30613;color:#e30613}
.hmf-policy{
    display:flex;
    flex-wrap:wrap;
    justify-content:flex-end;
    align-items:center;
    gap:6px 14px;
}
.hmf-policy a{
    color:#7a7a7a;
    font-size:11px;
    line-height:1.5;
    transition:color .15s;
}
.hmf-policy a:hover{color:#fff}
.hmf-policy a+a::before{
    content:'|';
    color:#4a4a4a;
    margin-right:14px;
}

.hmf-copyright{
    margin:10px 0 0;
    font-size:11px;
    line-height:1.6;
    color:#5f5f5f;
}

/* ===== PAGE TOP BTN ===== */
#page-top{position:fixed;bottom:28px;right:28px;width:44px;height:44px;background:#e30613;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transform:translateY(12px);transition:opacity .3s,transform .3s,background .2s;z-index:100;border:none}
#page-top.vis{opacity:1;transform:translateY(0)}
#page-top:hover{background:#c0000f}

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:#f1f1f1}
::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:#e30613}

/* ===== RESPONSIVE ===== */
@media(max-width:1280px){
    .mega-sidebar{width:236px}
    .mega-prod-grid{grid-template-columns:repeat(auto-fill,minmax(148px,148px))}
    .hmf-main{grid-template-columns:1fr}
    .hmf-links{grid-template-columns:repeat(3,minmax(0,1fr))}
    .hmf-subscribe{max-width:430px}
}
@media(max-width:900px){
    .header-topbar{display:none}
    #nav-inner{height:64px;padding-left:16px!important;padding-right:16px!important}
    #nav-inner>a img{height:24px}
    .desktop-nav{display:none!important}
    .desktop-actions{display:none!important}
    .mega-panel{display:none!important}
    #mobile-btn{
        display:flex!important;
        align-items:center;
        justify-content:center;
        margin-left:auto;
        padding:0;
    }
    #mobile-menu{
        position:fixed;
        top:64px;
        right:0;
        bottom:0;
        left:0;
        z-index:240;
        border-top:1px solid #eaeaea;
        background:#fff;
    }
    .mobile-main-list{
        padding-left:21px;
        padding-right:21px;
    }
    .mobile-sub-body{
        padding-left:21px;
        padding-right:21px;
    }
    #mobile-menu.open{display:block}
    #hero{height:560px}
    .slide-ct>div{padding-left:24px!important;padding-right:24px!important}
    .hero-h2{font-size:clamp(28px,7vw,38px)}
    .hero-p{font-size:14px;line-height:1.7;margin-bottom:22px;max-width:100%}
    .c-arrow{display:none}
    .c-dots{bottom:16px}
    .dot{width:22px;height:4px}
    .dot.active{width:34px}
    .feat-grid{grid-template-columns:1fr!important}
    .lineup-grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}
    .lineup-grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}
    .lineup-card-wide{grid-column:auto}
    .products-inner{padding:0 16px}
    .lineup-tabs{justify-content:flex-start;gap:12px;scroll-snap-type:x proximity}
    .lineup-tabs .tab-btn{font-size:12px;padding:8px 12px;min-height:36px;scroll-snap-align:start}
    .lineup-handheld-grid,
    .lineup-hero-grid-2,
    .lineup-instru-grid{grid-template-columns:1fr}
    .lineup-hero-card-fire{grid-column:auto}
    .lineup-hero-card-fixed,
    .lineup-hero-card-software{min-height:342px}
    .lineup-hero-card-fixed .lineup-hero-content,
    .lineup-hero-card-software .lineup-hero-content{max-width:84%}
    .lineup-hero-content{max-width:84%;padding:24px 24px 6px}
    .lineup-hero-picks{padding:0 24px 18px;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;scroll-snap-type:x mandatory}
    .lineup-hero-picks::-webkit-scrollbar{display:none}
    .lineup-hero-pick{flex:0 0 118px;scroll-snap-align:start}
    .lineup-gallery-wrap{padding:0 24px 18px}
    .hm-footer-inner{padding-left:16px;padding-right:16px}
    .hmf-links{grid-template-columns:repeat(2,minmax(0,1fr))}
    .hmf-bottom{grid-template-columns:1fr;justify-items:start}
    .hmf-policy{justify-content:flex-start}
}
@media(max-width:768px){
    #recommended{padding-top:44px;padding-bottom:40px}
    #product-experience{padding-top:48px;padding-bottom:48px}
    #articles > div{grid-template-columns:1fr!important}
    .article-copy{padding:24px 20px 16px}
}
@media(max-width:600px){
    #hero{height:500px}
    .slide-ct>div{padding-left:16px!important;padding-right:16px!important}
    .hero-tag{font-size:10px;letter-spacing:.12em;margin-bottom:10px}
    .hero-h2{font-size:clamp(24px,8vw,30px);line-height:1.3;margin-bottom:12px}
    .hero-p{font-size:13px;line-height:1.65;margin-bottom:18px}
    .hero-btn{padding:11px 22px;font-size:12px}
    .products-section{padding:20px 0 44px}
    .prod-grid{grid-template-columns:repeat(2,1fr)}
    .lineup-grid-2,
    .lineup-grid-3,
    .lineup-grid-4{grid-template-columns:1fr}
    .lineup-img{height:200px}
    .lineup-hero-card,
    .lineup-hero-card-fire{min-height:300px}
    .lineup-hero-card-fixed .lineup-hero-content,
    .lineup-hero-card-software .lineup-hero-content{max-width:100%}
    .lineup-hero-content{max-width:100%;padding:20px 16px 8px}
    .lineup-hero-content h3{font-size:27px}
    .lineup-hero-content p{font-size:13px}
    .lineup-hero-picks{gap:8px;padding:0 16px 14px}
    .lineup-hero-pick{flex-basis:110px;min-height:98px;padding:8px 6px}
    .lineup-hero-pick img{max-width:64px;max-height:54px}
    .lineup-hero-next{width:30px;min-height:98px}
    .lineup-gallery-wrap{gap:6px;padding:0 16px 14px}
    .lineup-gallery{scroll-snap-type:x mandatory}
    .lineup-gallery-track>.lineup-hero-pick{scroll-snap-align:start}
    .lineup-gallery-btn{display:none}
    #pocket-feature,
    #sp,
    #blog{padding-top:56px;padding-bottom:56px}
    #sp p{color:rgba(255,255,255,.78)!important}
    #articles .article-copy{padding:20px 16px 14px}
    #articles .article-copy h3{text-shadow:0 2px 12px rgba(0,0,0,.55)}
    #articles .article-copy p{line-height:1.6;color:rgba(255,255,255,.87)!important;text-shadow:0 1px 8px rgba(0,0,0,.45)}
    .hm-footer-inner{padding-top:30px;padding-bottom:16px}
    .hmf-main{gap:22px;padding-bottom:22px}
    .hmf-links{grid-template-columns:1fr;gap:15px}
    .hmf-col{padding-bottom:10px;border-bottom:1px solid #1e1e1e}
    .hmf-col:last-child{padding-bottom:0;border-bottom:none}
    .fl{font-size:13px;padding:5px 0}
    .hmf-subscribe{padding:18px 16px}
    .hmf-subscribe h4{font-size:20px}
    .hmf-subscribe-actions{grid-template-columns:1fr}
    .hmf-bottom{padding-top:16px}
    .hmf-policy{gap:6px 10px}
    .hmf-policy a{font-size:11px}
    .hmf-policy a+a::before{margin-right:10px}
    .soc-icon{color:#b4b4b4}
    #page-top{right:14px;bottom:18px}
}
@media(max-width:420px){
    .lineup-hero-pick{flex-basis:102px}
}

/* ===== RECOMMENDED INFORMATION CAROUSEL ===== */
/* shrink-0 relative overflow-hidden は Tailwind クラスで付与済み */
.rec-slide { cursor:pointer; }
.rec-slide.active { cursor:default; }
.rec-video { width:100%;height:100%;object-fit:cover;display:block;background:#111; }
.rec-ov {
    position:absolute;inset:0;
    background:transparent;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    color:#fff;
    opacity:0;
    transition:opacity .35s;
    pointer-events:none;
}
.rec-slide.active .rec-ov { opacity:1;pointer-events:auto; }
.rec-play-btn {
    width:64px;height:64px;border-radius:50%;
    border:2px solid rgba(255,255,255,.75);
    background:rgba(255,255,255,.12);
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;transition:background .2s,border-color .2s;
    padding:0;
}
.rec-play-btn:hover { background:rgba(255,255,255,.28);border-color:#fff; }
/* left-4 / right-4 は Tailwind クラスで付与済み */
.rec-arrow {
    position:absolute;top:50%;transform:translateY(-50%);
    width:52px;height:52px;border-radius:50%;
    background:rgba(0,0,0,.4);border:none;color:#fff;
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;z-index:10;transition:background .2s;
}
.rec-arrow:hover { background:rgba(227,6,19,.85); }
.rec-dot {
    width:10px;height:10px;border-radius:50%;
    border:none;background:#ccc;cursor:pointer;padding:0;
    transition:background .2s,transform .2s;
}
.rec-dot.active { background:#e30613;transform:scale(1.25); }
@media(max-width:768px){
    .rec-arrow{display:none!important}
    .rec-play-btn{width:56px;height:56px}
}

/* ===== ARTICLES / PRESS COVERAGE ===== */
@media(max-width:768px){
    #articles .grid.grid-cols-3 a{padding-left:4px;padding-right:4px}
    #articles .grid.grid-cols-3 a span{font-size:8px;line-height:1.35}
}
