
:root{
  --bg:#ffffff;
  --bg-soft:#f6f8fb;
  --paper:#ffffff;
  --text:#111827;
  --muted:#5f6673;
  --line:#d9dee7;
  --line-strong:#c6cfdd;
  --red:#d92f2f;
  --red-dark:#b62424;
  --gold:#c99a42;
  --dark:#0b2345;
  --dark-2:#12345c;
  --blue:#0b4b8f;
  --light-blue:#eef7ff;
  --shadow:0 8px 24px rgba(16,35,70,.08);
  --radius:14px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Hiragino Kaku Gothic ProN","Yu Gothic","Noto Sans JP",sans-serif;color:var(--text);background:#fff;line-height:1.75}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,select,textarea{font:inherit}
.container{width:min(1380px,calc(100% - 40px));margin:0 auto}
.section{padding:72px 0}.section.alt{background:#f6f8fb}
.topbar{background:#0b2345;color:#fff;font-size:13px;padding:9px 0}.topbar .container{display:flex;justify-content:space-between;gap:20px;align-items:center;flex-wrap:wrap}.topbar-tel{color:var(--red);font-weight:800}
.header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.98);backdrop-filter:blur(10px);border-bottom:1px solid #e8edf4;box-shadow:0 4px 20px rgba(11,35,69,.04)}
.header-inner{display:flex;align-items:center;gap:18px;min-height:88px}
.brand{display:flex;align-items:center;gap:12px;min-width:250px;flex-shrink:0}.brand-mark{width:54px;height:54px;border-radius:8px;object-fit:cover;box-shadow:0 4px 14px rgba(11,35,69,.12)}
.brand-title{font-size:17px;font-weight:800;letter-spacing:.02em;color:#111827;white-space:nowrap}.brand-sub{font-size:11px;color:#6b7280;letter-spacing:.12em;white-space:nowrap}
.nav{display:flex;align-items:center;gap:2px;flex:1;justify-content:center;flex-wrap:nowrap;min-width:0}.nav a{padding:12px 7px;font-weight:700;font-size:15px;color:#1f2937;border-bottom:3px solid transparent;transition:.2s;white-space:nowrap;word-break:keep-all}.nav a.active,.nav a:hover{color:var(--red);border-color:var(--red)}
.head-cta{display:flex;align-items:center;gap:12px;flex-shrink:0}.tel-mini{font-size:18px;font-weight:900;color:var(--red);line-height:1;white-space:nowrap}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;border-radius:8px;padding:12px 18px;font-weight:800;transition:.2s;box-shadow:none}
.btn:hover{transform:translateY(-1px)}
.btn-red{background:var(--red);color:#fff;box-shadow:0 8px 18px rgba(217,47,47,.18)}
.btn-dark{background:var(--dark);color:#fff}
.btn-outline{background:#fff;border:1px solid var(--line-strong);color:#0b2345}
.btn-gold{background:linear-gradient(180deg,#d8b56e,#b98e40);color:#fff}
.btn-wide{width:100%}
.mobile-menu-btn,.mobile-fixed,.mobile-drawer,.drawer-backdrop{display:none}
.mobile-menu-btn{width:52px;height:52px;border-radius:12px;border:1px solid var(--line);background:#fff;align-items:center;justify-content:center;flex-direction:column;gap:5px}.mobile-menu-btn span{width:22px;height:2px;background:#222;border-radius:2px}
.hero{padding:0;background:linear-gradient(135deg,#ffffff 0%,#f7fbff 54%,#eef6ff 100%);border-bottom:1px solid #e8edf4}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;align-items:center;gap:32px}
.eyebrow,.section-kicker{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:800;letter-spacing:.12em;color:var(--red);text-transform:uppercase}
.hero h1{font-size:54px;line-height:1.16;letter-spacing:.02em;margin:18px 0 18px;color:#0b2345}.hero h1 span{color:var(--red)}
.lead{font-size:18px;color:#4b5563;max-width:680px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}.trust{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}.trust span{padding:10px 14px;background:#fff;border:1px solid #dce5f1;border-radius:8px;font-weight:700;font-size:13px;color:#0b2345}
.hero-card{position:relative;min-height:430px;border-radius:18px;overflow:hidden;box-shadow:var(--shadow);background:#fff;border:1px solid #e1e7f0}.hero-card img{width:100%;height:100%;object-fit:cover}.caption{position:absolute;left:22px;bottom:22px;background:rgba(255,255,255,.94);backdrop-filter:blur(8px);padding:16px 18px;border-radius:10px;font-size:14px;max-width:360px;border-left:4px solid var(--red)}
.hero-card-banner img{object-position:center center}

.hero-cover{position:relative;overflow:hidden;min-height:333px;display:flex;align-items:center;background:#102238;border-bottom:1px solid #e8edf4}
.hero-cover::before{content:"";position:absolute;inset:0;background-image:linear-gradient(90deg,rgba(8,16,29,.84) 0%,rgba(8,16,29,.76) 28%,rgba(8,16,29,.48) 48%,rgba(8,16,29,.18) 68%,rgba(8,16,29,.06) 100%),url('../images/home-hero-banner.png');background-size:cover;background-position:center center}
.hero-cover .container{position:relative;z-index:2;width:min(1380px,calc(100% - 40px))}
.hero-cover-copy{max-width:700px;padding:44px 0}
.hero-cover .eyebrow{color:#ff665e}
.hero-cover h1{color:#ffffff;text-shadow:0 2px 18px rgba(0,0,0,.18)}
.hero-cover h1 span{color:#ff4a4a}
.hero-cover .lead{color:rgba(255,255,255,.88);max-width:640px}
.hero-cover .trust span{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);color:#fff;backdrop-filter:blur(6px)}
.hero-cover .btn-outline{background:rgba(255,255,255,.94);border-color:rgba(255,255,255,.94);color:#0b2345}
.hero-cover .btn-dark{background:#0b2345;color:#fff}
@media (max-width: 900px){
  .hero-card-banner img{object-position:68% center}
}
@media (max-width: 640px){
  .hero-card-banner img{object-position:74% center}
}



.page-hero{position:relative;min-height:300px;display:flex;align-items:center;overflow:hidden;background:#f7fbff;color:#171717;border-bottom:1px solid #e0e7f1}
.page-hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(90deg,rgba(247,251,255,.995) 0%,rgba(247,251,255,.97) 40%,rgba(247,251,255,.82) 58%,rgba(247,251,255,.42) 75%,rgba(247,251,255,.08) 100%),var(--hero-bg);background-size:cover;background-position:center right;filter:brightness(1.05) saturate(1.04)}
.page-hero::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:4px;background:linear-gradient(90deg,var(--red),#d7e6f6 70%,transparent 100%)}
.page-hero .container{position:relative;z-index:2;padding:58px 0}
.crumb{font-size:14px;color:var(--red);margin-bottom:12px;font-weight:800}.page-hero h1{font-size:56px;line-height:1.1;margin:0 0 14px;color:#0b2345}.page-hero p{font-size:18px;max-width:760px;margin:0;color:#4b5563}
.hero-items{--hero-bg:url('../images/page-yard.jpg')}
.hero-prices{--hero-bg:url('../images/page-materials.jpg')}
.hero-flow{--hero-bg:url('../images/page-flow.jpg')}
.hero-corporate{--hero-bg:url('../images/page-corporate.jpg')}
.hero-area{--hero-bg:url('../images/page-area.jpg')}
.hero-company{--hero-bg:url('../images/page-corporate.jpg')}
.hero-contact{--hero-bg:url('../images/page-materials.jpg')}
.hero-faq{--hero-bg:url('../images/page-yard.jpg')}
.hero-information{--hero-bg:url('../images/page-yard.jpg')}
.hero-information-detail{--hero-bg:url('../images/page-mixed.jpg')}


.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:26px}.section-title{font-size:42px;line-height:1.15;margin:8px 0 0}.section-desc{color:#666;max-width:720px}.note{padding:16px 20px;border:1px solid #e3c77e;background:#faf2dc;border-radius:14px;color:#6f5730}
.grid{display:grid;gap:24px}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--paper);border:1px solid #e1e7f0;border-radius:14px;box-shadow:var(--shadow)}
.category-card{overflow:hidden}.category-card img{width:100%;height:220px;object-fit:cover}.category-card .body{padding:22px}.category-card h3{font-size:26px;margin:0 0 8px;color:#0b2345}.category-card p{margin:0 0 14px;color:#5f6673}
.banner{position:relative;border-radius:28px;overflow:hidden;min-height:460px;box-shadow:var(--shadow);background:#111}.banner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.banner::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(13,15,19,.76),rgba(13,15,19,.18) 60%)}.banner-content{position:relative;z-index:2;padding:38px;color:#fff;max-width:620px}
.price-preview{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.price-tile{position:relative;display:flex;gap:18px;align-items:center;padding:18px;border-radius:20px;border:1px solid var(--line);background:#fff;min-height:148px;box-shadow:var(--shadow)}.price-tile img{width:90px;height:90px;border-radius:14px;object-fit:cover}.price-tile h3{margin:0 0 6px;font-size:20px}.price-tile .price{font-size:22px;font-weight:900;color:var(--red)}
.badge{position:absolute;left:10px;top:10px;padding:7px 12px;border-radius:999px;color:#fff;font-size:12px;font-weight:900;line-height:1;box-shadow:0 8px 18px rgba(0,0,0,.18)}
.badge.up{background:linear-gradient(180deg,#ff7a45,#d62828);animation:flamePulse 1.2s infinite ease-in-out}
.badge.down{background:linear-gradient(180deg,#1bb56c,#0b8d4b);animation:downPulse 1.2s infinite ease-in-out}
.badge.flat{background:#6f7782}
@keyframes flamePulse{0%,100%{transform:translateY(0) scale(1);box-shadow:0 8px 18px rgba(214,40,40,.22)}50%{transform:translateY(-2px) scale(1.06);box-shadow:0 12px 26px rgba(255,122,69,.36)}}
@keyframes downPulse{0%,100%{transform:translateY(0)}50%{transform:translateY(2px)}}
.home-news-section{padding-top:12px}.home-news-list{display:grid;gap:14px}.home-news-card{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px 22px;background:#fff;border:1px solid var(--line);border-radius:18px}.home-news-card .dot{width:10px;height:10px;border-radius:50%;background:var(--red);display:inline-block;margin-right:10px}.home-news-card small{color:#888;font-weight:700}
.info-list{display:grid;gap:18px}.info-card{display:grid;grid-template-columns:150px 1fr auto;align-items:center;gap:20px;padding:22px 24px;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow)}.info-label{display:inline-flex;align-items:center;justify-content:center;padding:7px 12px;border-radius:999px;background:#fbefe8;color:var(--red);font-size:12px;font-weight:900}
.detail-wrap{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:28px}.detail-article{background:#fff;border:1px solid var(--line);border-radius:24px;padding:32px;box-shadow:var(--shadow)}.detail-actions{display:flex;gap:12px;flex-wrap:wrap}
.layout{display:grid;grid-template-columns:280px minmax(0,1fr);gap:28px;align-items:start}.side{position:sticky;top:112px;padding:0;border-radius:24px}.side h3{background:#0b2345;color:#fff;padding:20px 22px;margin:0;border-radius:14px 14px 0 0;font-size:24px}.side button,.side a.side-banner{display:flex;width:100%;padding:17px 20px;border:0;border-top:1px solid #e1e7f0;background:#fff;font-weight:800;text-align:left;align-items:center;min-height:64px;color:#111827}.side button.active{background:#fff2f2;color:var(--red)}
.side-tools{display:grid;gap:12px;padding-top:14px}.market-widget{background:#fff;border:2px solid #1b64b1;border-radius:16px;padding:10px 10px 12px}.mw-title{background:#115ba7;color:#fff;font-weight:900;text-align:center;padding:10px 12px;border-radius:10px;font-size:18px}.mw-sub{text-align:center;font-weight:700;padding:10px 0 6px}.tv-compact-frame{border:1px solid #c8d7e8;border-radius:10px;overflow:hidden;background:#fff;height:276px}.tv-compact-frame iframe{width:100%;height:100%;border:0}.mw-note{font-size:13px;line-height:1.55;color:#c62828;margin:10px 0 0;text-align:center}
.side-banner{background:linear-gradient(180deg,#cfefff,#9fd4f4)!important;color:#123c6b !important;border-radius:14px;box-shadow:0 8px 20px rgba(0,0,0,.08);border:1px solid #8cc5e8 !important;display:flex;align-items:center;justify-content:flex-start;font-size:18px;line-height:1.35;text-shadow:0 1px 0 rgba(255,255,255,.65)}
.side-banner.q{background:linear-gradient(180deg,#bfe8fb,#78c2e9)!important}.side-banner.machine{background:linear-gradient(180deg,#d3f0ff,#91d0ee)!important}.side-banner.cutter{background:linear-gradient(180deg,#c7ecff,#8fcfeb)!important}
.searchbar{display:flex;gap:14px;margin-bottom:16px}.searchbar input{flex:1;border:1px solid var(--line-strong);border-radius:18px;padding:18px 18px;background:#fff}
.price-list{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.price-list .card{position:relative;display:flex;gap:18px;padding:18px;align-items:center;min-height:162px}.price-list img{width:120px;height:120px;border-radius:16px;object-fit:cover}.price-list h3{margin:0 0 8px;font-size:28px}.price-list p{margin:0;color:#666}.price-list .price{font-size:42px;font-weight:900;color:var(--red);margin-top:12px;line-height:1.1}.price-list .body{display:flex;flex-direction:column;gap:4px;min-width:0}.price-list .body small{color:#999}
.flow-intro{display:grid;grid-template-columns:1.05fr .95fr;gap:24px;align-items:start;margin-bottom:28px}.flow-intro-card{background:linear-gradient(180deg,#17191e,#101114);color:#fff;padding:28px;border-radius:24px;box-shadow:var(--shadow)}.flow-methods{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.flow-method{background:#fff;border:1px solid var(--line);border-radius:22px;padding:22px;box-shadow:var(--shadow)}.flow-method .icon{font-size:30px;margin-bottom:12px}
.tabs{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:24px}.tab{padding:12px 22px;border:1px solid var(--line-strong);border-radius:999px;background:#fff;font-weight:800}.tab.active{background:#0f1114;color:#fff;border-color:#0f1114}
.flow-timeline{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}.flow-node{background:#fff;border:1px solid var(--line);border-radius:22px;padding:24px;box-shadow:var(--shadow);position:relative;min-height:230px}.flow-node .num{width:44px;height:44px;border-radius:50%;background:var(--red);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:900;font-size:20px;margin-bottom:18px;box-shadow:0 8px 20px rgba(201,40,40,.25)}
.case-card{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:center;padding:22px;overflow:hidden}.case-card img{width:100%;height:360px;object-fit:cover;border-radius:18px}
.reason{padding:24px}.reason h3,.reason h2{margin:0 0 8px}.reason p{margin:0;color:#666}
.area-stack{display:grid;gap:28px}.area-block{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:stretch}.area-block.reverse{grid-template-columns:1fr 1fr}.area-info{background:#fff;border:1px solid var(--line);border-radius:24px;padding:30px;box-shadow:var(--shadow);display:flex;flex-direction:column;justify-content:center}.area-info h2{font-size:36px;margin:0 0 10px}.tel{font-size:48px;font-weight:900;color:var(--red);line-height:1.1;margin:10px 0 12px}.map-card{overflow:hidden;border-radius:24px;box-shadow:var(--shadow);min-height:340px}.map-card iframe{width:100%;height:100%;border:0;min-height:340px}
.company-main{display:grid;gap:24px}.company-table{display:grid;gap:8px;margin-top:18px}.company-table dl{display:grid;grid-template-columns:160px 1fr;gap:16px;padding:14px 0;border-bottom:1px dashed var(--line)}.company-table dt{font-weight:900}.company-image-slot{min-height:340px;border-radius:24px;border:2px dashed #d0c5b0;background:linear-gradient(135deg,#f8f2e9,#eee5d7);display:flex;align-items:center;justify-content:center;color:#88734d;font-weight:800;font-size:22px;text-align:center;padding:20px}
.form{background:#fff;border:1px solid var(--line);border-radius:24px;padding:28px;box-shadow:var(--shadow)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.field{display:grid;gap:8px}.field label{font-weight:800}.field input,.field textarea,.field select{padding:14px 15px;border-radius:14px;border:1px solid var(--line-strong);background:#fff}.field textarea{min-height:180px;resize:vertical}.field.full{grid-column:1/-1}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:20px;padding:22px 24px;box-shadow:var(--shadow)}.faq-item+.faq-item{margin-top:16px}.faq-q{font-size:22px;font-weight:900;margin-bottom:10px}.faq-a{color:#555}
.footer{background:#0b2345;color:#fff;padding:56px 0 80px;margin-top:0}.footer-grid{display:grid;grid-template-columns:1.05fr .8fr 1fr;gap:32px;align-items:start}.footer h3{margin:0 0 12px}.footer .brand-title{font-size:28px}.footer p,.footer a{color:rgba(255,255,255,.86)}.footer-copy{margin-top:20px;color:rgba(255,255,255,.5);font-size:13px}.footer-map{display:grid;gap:10px}.footer-map select{padding:14px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.18);background:#fff;color:#111}.footer-map iframe{width:100%;height:240px;border:0;border-radius:16px;background:#fff}
.mobile-fixed{position:fixed;left:10px;right:10px;bottom:10px;z-index:55;background:#fff;border-radius:16px;box-shadow:0 16px 40px rgba(0,0,0,.18);overflow:hidden}
.mobile-fixed a{flex:1;text-align:center;padding:14px 10px;font-weight:900}.mobile-fixed a:nth-child(1){background:#111;color:#fff}.mobile-fixed a:nth-child(2){background:#f0ebe1}.mobile-fixed a:nth-child(3){background:var(--red);color:#fff}

@media (max-width:1320px){
  .nav{display:none}.mobile-menu-btn{display:flex}.head-cta .btn{display:none}.header-inner{min-height:84px}.tel-mini{font-size:22px}
  .mobile-drawer{display:block;position:fixed;top:0;right:-100%;width:min(420px,100%);height:100vh;background:#fff;z-index:80;transition:right .25s ease;overflow:auto}
  .mobile-drawer.open{right:0}.drawer-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:70}.drawer-backdrop.show{display:block}.mobile-drawer-head{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--line)}.drawer-logo{display:flex;gap:12px;align-items:center}.drawer-logo img{width:48px;height:48px;border-radius:10px;object-fit:cover}.drawer-logo b{display:block;font-size:18px}.drawer-logo small{display:block;color:#777}.mobile-close{width:44px;height:44px;border:none;border-radius:10px;background:#131722;color:#fff;font-size:28px;cursor:pointer}.mobile-drawer-nav{display:grid}.mobile-drawer-nav a{padding:18px 22px;border-bottom:1px solid #eee;font-weight:800}.drawer-contact{padding:24px 22px;border-top:1px solid var(--line);display:grid;gap:8px}.drawer-contact span{display:inline-flex;align-self:flex-start;background:#e54040;color:#fff;border-radius:10px;padding:8px 12px;font-size:13px;font-weight:800}.drawer-contact a{font-size:34px;font-weight:900;line-height:1.05}
  .hero-grid,.flow-intro,.case-card,.detail-wrap,.layout,.footer-grid,.area-block,.area-block.reverse{grid-template-columns:1fr}.grid-3,.grid-4,.price-preview,.price-list,.flow-methods,.flow-timeline{grid-template-columns:repeat(2,1fr)}
  .side{position:static}.page-hero h1{font-size:48px}.hero h1{font-size:46px}.hero-card{min-height:360px}
}
@media (max-width:768px){
  body{padding-bottom:76px}.container{width:min(100% - 24px,1240px)}.topbar{display:none}.brand{min-width:0}.brand-title{font-size:16px}.brand-sub{font-size:11px}.brand-mark{width:50px;height:50px}.head-cta .tel-mini{font-size:0;display:none}.page-hero{min-height:260px}.page-hero .container{padding:44px 0}.page-hero h1{font-size:42px}.page-hero p{font-size:16px}.hero{padding:48px 0}.hero h1{font-size:38px}.lead{font-size:16px}.hero-actions,.detail-actions,.searchbar{display:grid;grid-template-columns:1fr}.hero-card{min-height:280px}.hero-cover{min-height:auto}.hero-cover::before{background-image:linear-gradient(180deg,rgba(8,16,29,.70) 0%,rgba(8,16,29,.54) 32%,rgba(8,16,29,.28) 58%,rgba(8,16,29,.18) 100%),url('../images/home-hero-banner.png');background-position:64% center}.hero-cover-copy{max-width:100%;padding:48px 0 44px}.hero-cover h1{font-size:42px;line-height:1.15}.hero-cover .lead{font-size:16px;max-width:none}.hero-cover .trust{gap:8px}.hero-cover .trust span{font-size:12px;padding:9px 12px}
  .grid-3,.grid-4,.price-preview,.price-list,.flow-methods,.flow-timeline,.form-grid{grid-template-columns:1fr}.price-tile,.price-list .card,.info-card{grid-template-columns:1fr;display:grid;align-items:start}.price-list .price{font-size:34px}.category-card h3,.area-info h2{font-size:30px}.section,.section.alt{padding:56px 0}.section-title{font-size:34px}.tel{font-size:36px}.company-table dl{grid-template-columns:1fr}.footer{padding-bottom:120px}.mobile-fixed{display:flex}.tv-compact-frame{height:240px}.home-news-card{display:grid;justify-content:flex-start}
  #purchase-items .grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}
}


/* ===== v1.1 targeted layout fixes ===== */
.side button{cursor:pointer;transition:background .18s ease,color .18s ease,padding-left .18s ease,border-color .18s ease;position:relative}
.side button:hover{background:#fff7f7;color:var(--red);padding-left:24px}
.side button::before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:var(--red);transition:width .18s ease}
.side button:hover::before,.side button.active::before{width:4px}
.side button.active{background:#fff2f2;color:var(--red)}

/* homepage flow section */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;counter-reset:homeflow}
.step{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px 22px 22px;box-shadow:var(--shadow);position:relative;min-height:170px}
.step::before{counter-increment:homeflow;content:counter(homeflow);position:absolute;left:24px;top:20px;width:34px;height:34px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;box-shadow:0 8px 16px rgba(217,47,47,.22)}
.step h3{margin:38px 0 10px;font-size:20px;color:#111827}.step p{margin:0;color:#5f6673;line-height:1.8}

/* price card desktop/mobile */
.price-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.price-list .card{position:relative;display:flex;gap:18px;padding:18px;align-items:center;min-height:162px;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow)}
.price-list .card .badge{position:absolute;left:12px;top:12px;z-index:2}
.price-list .body{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}
.price-list h3{margin:0 0 8px;font-size:28px}
.price-list p{margin:0;color:#666;line-height:1.7}
.price-list .price{font-size:42px;font-weight:900;color:var(--red);margin-top:12px;line-height:1.1}
.price-list .body small{display:block;margin-top:10px;padding-top:10px;border-top:1px solid #e7ebf0;color:#999}

/* flow detail page */
.flow-intro{display:grid;grid-template-columns:1.05fr .95fr;gap:24px;align-items:start;margin-bottom:28px}
.flow-intro-card{background:linear-gradient(180deg,#0d0f14,#050607);color:#fff;padding:34px;border-radius:26px;box-shadow:var(--shadow);min-height:220px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.flow-intro-card::after{content:"";position:absolute;right:-40px;bottom:-40px;width:150px;height:150px;background:radial-gradient(circle,rgba(217,47,47,.55),rgba(217,47,47,0) 70%)}
.flow-intro-card h2{font-size:24px;line-height:1.55;margin:16px 0}.flow-intro-card p{margin:0;color:rgba(255,255,255,.88);line-height:1.9;position:relative;z-index:1}
.flow-methods{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.flow-method{background:#fff;border:1px solid var(--line);border-radius:22px;padding:22px 22px 26px;box-shadow:var(--shadow);position:relative}
.flow-method::before{content:"";position:absolute;left:0;top:0;width:58px;height:4px;background:var(--red);border-radius:22px 0 8px 0}
.flow-method .icon{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#101114;color:#fff;font-size:22px;margin-bottom:18px}
.flow-method h3{margin:0 0 10px;font-size:18px}.flow-method p{margin:0;color:#5f6673;line-height:1.9}
.tabs{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:24px}.tab{padding:12px 22px;border:1px solid var(--line-strong);border-radius:999px;background:#fff;font-weight:800}.tab.active{background:#0f1114;color:#fff;border-color:#0f1114}
.flow-timeline.vertical{display:grid;grid-template-columns:1fr;gap:18px;position:relative;padding-left:82px}
.flow-timeline.vertical::before{content:"";position:absolute;left:26px;top:24px;bottom:24px;width:2px;background:#d93333}
.flow-node{position:relative;background:#fff;border:1px solid var(--line);border-radius:22px;padding:28px 28px 24px;box-shadow:var(--shadow);min-height:auto}
.flow-node .num{position:absolute;left:-82px;top:28px;width:52px;height:52px;border-radius:50%;background:var(--red);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:900;font-size:24px;box-shadow:0 10px 20px rgba(217,47,47,.24)}
.flow-node h3{margin:0 0 12px;font-size:20px}.flow-node p{margin:0;color:#5f6673;line-height:1.9}.flow-node ul{margin:12px 0 0 18px;color:#374151;line-height:1.9}

/* information list page */
.info-layout{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:26px;align-items:start}
.info-list{display:grid;gap:18px}
.info-card{display:block;background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);overflow:hidden}
.info-card a{display:block;padding:26px 24px;color:inherit}
.info-card:hover{border-color:#f0a7a7;transform:translateY(-1px)}
.info-card time{font-size:16px;font-weight:900;color:#4b5563}
.info-label{display:inline-flex;align-items:center;justify-content:center;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:900;margin-left:10px;vertical-align:middle}
.info-label.price{background:#fde8e6;color:#d92f2f}.info-label.service{background:#111827;color:#fff}.info-label.office{background:#d7ab47;color:#111}.info-label.antique{background:#a47626;color:#fff}
.info-card h2{margin:18px 0 12px;font-size:22px;line-height:1.6;color:#111827}.info-card p{margin:0;color:#6b7280;line-height:1.9}
.info-side{background:#fff;border:1px solid var(--line);border-radius:22px;padding:22px;box-shadow:var(--shadow);position:sticky;top:110px}
.info-side h3{margin:0 0 14px;font-size:18px}
.info-side a{display:block;padding:14px 0;border-bottom:1px solid #eceff4;font-weight:800;color:#111827}
.info-side a:last-child{border-bottom:none}
.info-side .btn{margin-top:18px;text-align:center;padding-left:0;padding-right:0}

/* information detail page */
.detail-article h2{margin:18px 0 0;font-size:28px;line-height:1.5;color:#111827}
.detail-article .detail-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.detail-article .detail-meta time{font-size:16px;font-weight:900;color:#4b5563;white-space:nowrap}
.detail-article .detail-meta .info-label{margin-left:0}
.detail-article .detail-content{margin-top:18px;color:#374151;line-height:1.9}
.detail-article .detail-content p{margin:0 0 16px}
.detail-article .detail-content p:last-child,.detail-article .detail-rich p:last-child{margin-bottom:0}
.detail-article .detail-actions{margin-top:32px;padding-top:8px}

/* contact phone card */
.contact-layout{grid-template-columns:320px minmax(0,1fr)}
.contact-side{padding:0;overflow:hidden;position:sticky;top:112px}
.contact-side h3{margin:0;background:linear-gradient(180deg,#111319,#07080b);color:#fff;padding:24px 22px;font-size:22px}
.contact-side a,.contact-side .contact-meta{display:block;padding:18px 22px;border-top:1px solid #eceff4;font-size:16px;line-height:1.7;background:#fff}
.contact-side a b{color:var(--red)}
.contact-side a{font-size:18px;font-weight:900;color:#111827}
.contact-side .contact-meta{font-weight:800;color:#111827}

@media (max-width:1320px){
  .steps{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:1024px){
  .price-list{grid-template-columns:repeat(2,minmax(0,1fr))}
  .flow-intro{grid-template-columns:1fr}
  .flow-methods{grid-template-columns:repeat(3,1fr)}
  .info-layout{grid-template-columns:1fr}
  .info-side{position:static}
  .contact-layout{grid-template-columns:1fr}
  .contact-side{position:static}
}
@media (max-width:768px){
  .steps{grid-template-columns:1fr;gap:14px}
  .step{min-height:auto}
  .price-list{grid-template-columns:1fr}
  .price-list .card{display:block;padding:0;overflow:hidden}
  .price-list .card .badge{left:10px;top:10px}
  .price-list img{display:block;width:100%;height:190px;border-radius:0;object-fit:cover}
  .price-list .body{display:block;padding:18px}
  .price-list h3{font-size:22px;margin:0 0 10px}
  .price-list p{font-size:14px}
  .price-list .price{font-size:26px;margin-top:16px}
  .price-list .body small{margin-top:14px;padding-top:14px;display:flex;justify-content:space-between;gap:8px;align-items:center}
  .flow-methods{grid-template-columns:1fr}
  .flow-timeline.vertical{padding-left:0}
  .flow-timeline.vertical::before{display:none}
  .flow-node{padding:24px 20px 20px}
  .flow-node .num{position:relative;left:auto;top:auto;margin:0 0 16px}
  .info-card a{padding:22px 18px}
  .info-card h2{font-size:18px}
  .contact-side a{font-size:16px}
}

.price-list .body small{display:flex;align-items:center;gap:8px}.price-list .body small .consult{margin-left:auto;color:var(--red);font-weight:800}


/* ===== v1.2 fixes from latest review ===== */

/* Information category sidebar: keep card white, make CTA readable */
.info-side{
  color:#0b2345;
}
.info-side h3,
.info-side a:not(.btn){
  color:#0b2345;
}
.info-side .btn,
.info-side .btn-red,
.info-side a.btn,
.info-side a.btn-red{
  background:var(--red) !important;
  color:#fff !important;
  border-color:var(--red) !important;
}

/* Contact phone card: header uses #0b2345, content text uses #0b2345 */
.contact-side h3{
  background:#0b2345 !important;
  color:#fff !important;
}
.contact-side a,
.contact-side .contact-meta{
  color:#0b2345 !important;
}
.contact-side a b{
  color:var(--red) !important;
}

/* Mobile header: change hamburger from rounded outline to dark block */
@media (max-width:1320px){
  .mobile-menu-btn{
    width:56px;
    height:56px;
    border-radius:0;
    border:0;
    background:#0b2345;
    box-shadow:none;
  }
  .mobile-menu-btn span{
    width:28px;
    height:3px;
    background:#fff;
    border-radius:2px;
  }
}

/* Drawer menu: match the clear white side-menu style with dark close block */
.mobile-drawer{
  background:#fff;
}
.mobile-drawer-head{
  min-height:72px;
  padding:10px 12px;
}
.mobile-close{
  width:58px;
  height:58px;
  border-radius:0;
  background:#101827;
  color:#fff;
  font-size:34px;
}
.mobile-drawer-nav a{
  position:relative;
  color:#0b2345;
  font-weight:900;
  padding:19px 30px;
}
.mobile-drawer-nav a::after{
  content:"›";
  position:absolute;
  right:18px;
  top:50%;
  transform:translateY(-50%);
  color:var(--red);
  font-size:28px;
  font-weight:900;
}
.drawer-contact a{
  color:#0b2345;
}

/* Price cards: restore V0.6-style compact horizontal layout on mobile */
@media (max-width:768px){
  .price-list .card{
    display:flex !important;
    flex-direction:row !important;
    align-items:center !important;
    gap:18px !important;
    padding:18px !important;
    min-height:162px !important;
    overflow:visible !important;
    border-radius:18px !important;
  }
  .price-list img{
    width:120px !important;
    height:120px !important;
    border-radius:16px !important;
    object-fit:cover !important;
    flex:0 0 120px !important;
  }
  .price-list .body{
    display:flex !important;
    flex-direction:column !important;
    gap:4px !important;
    padding:0 !important;
    min-width:0 !important;
    flex:1 !important;
  }
  .price-list h3{
    font-size:24px !important;
    margin:0 0 8px !important;
    color:#0b2345;
  }
  .price-list p{
    font-size:14px !important;
    line-height:1.7 !important;
    margin:0 !important;
  }
  .price-list .price{
    font-size:40px !important;
    line-height:1.08 !important;
    margin-top:12px !important;
  }
  .price-list .body small{
    display:flex !important;
    align-items:center !important;
    gap:8px !important;
    margin-top:10px !important;
    padding-top:10px !important;
    border-top:1px solid #e7ebf0 !important;
  }
  .price-list .body small .consult{
    margin-left:auto;
    color:var(--red);
    font-weight:800;
  }
  .price-list .card .badge{
    left:10px !important;
    top:10px !important;
    z-index:2 !important;
  }
}

@media (max-width:420px){
  .brand{
    min-width:0;
    gap:10px;
  }
  .brand-title{
    font-size:16px;
  }
  .brand-sub{
    font-size:10px;
  }
  .brand-mark{
    width:50px;
    height:50px;
  }
  .header-inner{
    min-height:72px;
    gap:10px;
  }
  .mobile-menu-btn{
    width:54px;
    height:54px;
    flex:0 0 54px;
  }
}


/* ===== v1.3 force price cards to vertical reference layout ===== */
.price-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px !important}
.price-list .card{
  display:block !important;
  padding:0 !important;
  min-height:0 !important;
  overflow:hidden !important;
  border-radius:20px !important;
  background:#fff !important;
  border:1px solid #d9dee7 !important;
  box-shadow:0 8px 24px rgba(16,35,70,.08) !important;
}
.price-list .card .badge{left:0 !important;top:0 !important;border-radius:20px 0 14px 0 !important;box-shadow:none !important}
.price-list .card img{
  width:100% !important;
  height:180px !important;
  display:block !important;
  border-radius:0 !important;
  object-fit:cover !important;
}
.price-list .card .body{
  display:block !important;
  padding:18px 18px 16px !important;
}
.price-list .card h3{
  margin:0 0 10px !important;
  font-size:20px !important;
  line-height:1.4 !important;
  color:#222 !important;
}
.price-list .card p{
  margin:0 0 18px !important;
  font-size:14px !important;
  line-height:1.85 !important;
  color:#777 !important;
}
.price-list .card .price{
  margin-top:0 !important;
  margin-bottom:14px !important;
  font-size:28px !important;
  line-height:1.15 !important;
  color:#d92f2f !important;
  font-weight:900 !important;
}
.price-list .card .body small{
  display:flex !important;
  justify-content:space-between !important;
  align-items:center !important;
  gap:12px !important;
  margin-top:0 !important;
  padding-top:12px !important;
  border-top:1px solid #eceff4 !important;
  color:#9aa0aa !important;
  line-height:1.6 !important;
}
.price-list .card .body small span:first-child{color:#9aa0aa !important}
.price-list .card .body small .consult{color:#d92f2f !important;font-weight:800 !important}

@media (max-width:1024px){
  .price-list{grid-template-columns:repeat(2,minmax(0,1fr)) !important}
}
@media (max-width:768px){
  .price-list{grid-template-columns:1fr !important}
  .price-list .card img{height:210px !important}
  .price-list .card .body{padding:18px 16px 16px !important}
  .price-list .card h3{font-size:18px !important}
  .price-list .card .price{font-size:26px !important}
}


/* v1.4 special purchase banner image */
.banner-full{padding:0 !important;background:transparent !important;border:none !important;box-shadow:none !important}
.banner-full a{display:block}
.banner-full img{display:block;width:100%;height:auto;border-radius:26px;box-shadow:0 10px 30px rgba(16,35,69,.12)}
@media (max-width:768px){
  .banner-full img{border-radius:18px}
}


/* ===== v1.4 based fix: mobile header / cards / footer ===== */

/* mobile hamburger: always sit at the right side */
@media (max-width:1320px){
  .header-inner{
    justify-content:space-between;
  }
  .brand{
    flex:1 1 auto;
    min-width:0;
  }
  .mobile-menu-btn{
    margin-left:auto;
    flex:0 0 56px;
    width:56px;
    height:56px;
  }
}

/* Section header CTA: mobile becomes a full separate row */
@media (max-width:768px){
  .section-head{
    display:block;
  }
  .section-head .btn{
    display:flex;
    width:100%;
    margin-top:18px;
    min-height:54px;
  }
}

/* Home price cards on mobile: reduce empty right area */
@media (max-width:768px){
  .price-preview{
    display:grid;
    grid-template-columns:1fr;
    gap:14px;
  }
  .price-tile{
    display:grid;
    grid-template-columns:96px minmax(0,1fr);
    align-items:center;
    gap:16px;
    min-height:132px;
    padding:16px;
  }
  .price-tile img{
    width:96px;
    height:96px;
  }
  .price-tile h3{
    font-size:20px;
  }
  .price-tile .price{
    font-size:24px;
    line-height:1.2;
  }
}

/* Item category buttons: align consistently */
.category-card{
  display:flex;
  flex-direction:column;
  height:100%;
}
.category-card .body{
  display:flex;
  flex-direction:column;
  flex:1;
}
.category-card .body p:last-child{
  display:flex;
  gap:10px;
  align-items:stretch;
  margin-top:auto;
  margin-bottom:0;
  padding-top:10px;
}
.category-card .body p:last-child .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:0;
  min-height:52px;
  white-space:nowrap;
}
.category-card .body p:last-child .btn-outline{
  min-width:118px;
}
.category-card .body p:last-child .btn-red{
  min-width:108px;
}

/* Remove unwanted small red decorative line on cards, if inherited */
.category-card::before,
.category-card::after{
  display:none !important;
}

/* Footer: logo + white text + no mobile overflow */
.footer{
  overflow:hidden;
}
.footer .container,
.footer-grid,
.footer-map{
  min-width:0;
}
.footer-brand{
  display:flex;
  align-items:center;
  gap:16px;
  margin-bottom:16px;
}
.footer-brand img{
  width:66px;
  height:66px;
  object-fit:cover;
  border-radius:12px;
  background:#fff;
  padding:4px;
  box-shadow:0 8px 20px rgba(0,0,0,.18);
  flex:0 0 66px;
}
.footer .brand-title{
  color:#fff !important;
  font-size:28px;
  line-height:1.2;
  margin:0;
}
.footer .brand-sub{
  color:rgba(255,255,255,.78) !important;
  margin-top:6px;
  font-size:13px;
  letter-spacing:.14em;
}
.footer p,
.footer p a,
.footer h3,
.footer label,
.footer-copy{
  color:#fff !important;
}
.footer p{
  opacity:.94;
}
.footer-copy{
  opacity:.72;
}
.footer-map select,
.footer-map iframe{
  width:100%;
  max-width:100%;
  min-width:0;
  box-sizing:border-box;
}
.footer-map iframe{
  display:block;
}

@media (max-width:768px){
  .footer-grid{
    grid-template-columns:1fr !important;
    gap:28px;
  }
  .footer-brand{
    align-items:flex-start;
  }
  .footer-brand img{
    width:58px;
    height:58px;
    flex-basis:58px;
  }
  .footer-map{
    width:100%;
    overflow:hidden;
  }
  .footer-map select{
    font-size:14px;
    height:54px;
  }
  .footer-map iframe{
    height:230px;
    border-radius:14px;
  }
}


/* ===== mobile square banner on v1.4 base ===== */
.banner.banner-full{
  display:block !important;
  min-height:auto !important;
  height:auto !important;
  padding:0 !important;
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
  overflow:visible !important;
}
.banner-full a,
.banner-full picture{
  display:block;
  width:100%;
}
.banner-full img{
  display:block;
  width:100%;
  height:auto;
  max-width:100%;
  border-radius:26px;
  box-shadow:0 10px 30px rgba(16,35,69,.12);
}
@media (max-width:768px){
  .banner.banner-full{
    border-radius:20px !important;
  }
  .banner-full img{
    border-radius:20px;
  }
}


/* ===== fix: prevent price cards from overlapping the special banner ===== */
.banner-full{
  position:relative;
  z-index:1;
  margin-bottom:42px !important;
}
.banner-full + *,
.section.alt + .section{
  position:relative;
  z-index:1;
}
.price-preview{
  position:relative;
  z-index:1;
  margin-top:0 !important;
  transform:none !important;
}
.price-tile{
  transform:none !important;
}

/* If any card/price section used negative positioning, reset it */
.section .price-preview,
.section .price-tile{
  top:auto !important;
}

@media (max-width:768px){
  .banner-full{
    margin-bottom:34px !important;
  }
  .section.alt:has(.banner-full){
    padding-bottom:36px !important;
  }
  .section.alt:has(.banner-full) + .section{
    padding-top:44px !important;
  }
}


/* ===== hard fix: special banner must occupy real height, no overlay ===== */
.banner.banner-full{
  position:relative !important;
  display:block !important;
  width:100% !important;
  height:auto !important;
  min-height:0 !important;
  padding:0 !important;
  margin:0 0 48px 0 !important;
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
  overflow:visible !important;
}
.banner.banner-full::before,
.banner.banner-full::after{
  display:none !important;
  content:none !important;
}
.banner-full a,
.banner-full picture{
  position:static !important;
  display:block !important;
  width:100% !important;
  height:auto !important;
}
.banner-full img{
  position:static !important;
  inset:auto !important;
  display:block !important;
  width:100% !important;
  height:auto !important;
  max-width:100% !important;
  object-fit:contain !important;
  border-radius:26px !important;
  box-shadow:0 10px 30px rgba(16,35,69,.12) !important;
}

/* ensure next price section always starts below banner */
.section.alt:has(.banner-full){
  padding-bottom:0 !important;
}
.section.alt:has(.banner-full) + .section{
  clear:both !important;
  padding-top:64px !important;
  position:relative !important;
  z-index:1 !important;
  background:#fff !important;
}
.section.alt:has(.banner-full) + .section .section-head,
.section.alt:has(.banner-full) + .section .price-preview{
  position:relative !important;
  z-index:1 !important;
  margin-top:0 !important;
  transform:none !important;
  top:auto !important;
}

@media (max-width:768px){
  .banner.banner-full{
    margin-bottom:36px !important;
    border-radius:20px !important;
  }
  .banner-full img{
    border-radius:20px !important;
  }
  .section.alt:has(.banner-full) + .section{
    padding-top:52px !important;
  }
}


/* ===== trend badge image replacement + motion ===== */
.badge{
  position:absolute;
  left:10px;
  top:10px;
  display:block;
  width:58px !important;
  height:58px !important;
  padding:0 !important;
  border-radius:0 !important;
  background-repeat:no-repeat !important;
  background-position:center center !important;
  background-size:contain !important;
  color:transparent !important;
  font-size:0 !important;
  line-height:0 !important;
  text-indent:-9999px !important;
  overflow:visible !important;
  box-shadow:none !important;
  z-index:4;
  transform-origin:center center;
  will-change:transform, filter, opacity;
}
.badge::after{
  content:"";
  position:absolute;
  inset:-8px;
  border-radius:50%;
  pointer-events:none;
  opacity:.6;
  z-index:-1;
  filter:blur(12px);
}
.badge.up{
  background-image:url('../images/badge-up.png') !important;
  animation:badgeFlameFloat 1.7s ease-in-out infinite, badgeFlamePulse 1.7s ease-in-out infinite;
}
.badge.up::after{
  background:radial-gradient(circle, rgba(255,123,32,.45) 0%, rgba(255,123,32,.18) 45%, rgba(255,123,32,0) 75%);
}
.badge.down{
  background-image:url('../images/badge-down.png') !important;
  animation:badgeArrowDrop 1.9s ease-in-out infinite, badgeArrowGlow 1.9s ease-in-out infinite;
}
.badge.down::after{
  background:radial-gradient(circle, rgba(136,230,38,.42) 0%, rgba(136,230,38,.18) 45%, rgba(136,230,38,0) 75%);
}
.badge.flat{display:none !important;}
@keyframes badgeFlameFloat{
  0%{transform:translateY(0) scale(1) rotate(-2deg);} 
  25%{transform:translateY(-3px) scale(1.03) rotate(1deg);} 
  50%{transform:translateY(-6px) scale(1.07) rotate(-1deg);} 
  75%{transform:translateY(-2px) scale(1.02) rotate(1deg);} 
  100%{transform:translateY(0) scale(1) rotate(-2deg);} 
}
@keyframes badgeFlamePulse{
  0%,100%{filter:drop-shadow(0 8px 14px rgba(255,116,0,.28)) brightness(1);} 
  50%{filter:drop-shadow(0 14px 22px rgba(255,116,0,.48)) brightness(1.08);} 
}
@keyframes badgeArrowDrop{
  0%,100%{transform:translateY(0) scale(1);} 
  35%{transform:translateY(4px) scale(1.05);} 
  60%{transform:translateY(8px) scale(1.08);} 
}
@keyframes badgeArrowGlow{
  0%,100%{filter:drop-shadow(0 8px 16px rgba(118,215,43,.24)) brightness(1);} 
  50%{filter:drop-shadow(0 14px 24px rgba(118,215,43,.44)) brightness(1.06);} 
}
.price-tile .badge,
.price-list .card .badge{
  width:58px !important;
  height:58px !important;
  left:10px !important;
  top:10px !important;
}
@media (max-width:768px){
  .badge,.price-tile .badge,.price-list .card .badge{
    width:52px !important;
    height:52px !important;
    left:8px !important;
    top:8px !important;
  }
  .badge::after{ inset:-6px; }
}
@media (max-width:420px){
  .badge,.price-tile .badge,.price-list .card .badge{
    width:46px !important;
    height:46px !important;
    left:6px !important;
    top:6px !important;
  }
  .badge::after{ inset:-5px; }
}
}


/* ===== trend badge with text + price trend styling ===== */
.badge,
.price-tile .badge,
.price-list .card .badge{
  width:auto !important;
  min-width:92px;
  height:38px !important;
  padding:0 14px 0 46px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  gap:4px;
  border-radius:999px !important;
  background-image:none !important;
  background-repeat:no-repeat !important;
  background-size:0 0 !important;
  color:#fff !important;
  font-size:14px !important;
  line-height:1 !important;
  font-weight:900 !important;
  letter-spacing:.02em;
  text-indent:0 !important;
  overflow:visible !important;
  white-space:nowrap;
  box-shadow:0 10px 20px rgba(0,0,0,.12) !important;
}
.badge::before{
  content:"";
  position:absolute;
  left:8px;
  top:50%;
  width:24px;
  height:24px;
  transform:translateY(-50%);
  background-repeat:no-repeat;
  background-position:center;
  background-size:contain;
}
.badge.up{background:linear-gradient(180deg,#ff8a35 0%, #ff541f 100%) !important;}
.badge.up::before{background-image:url('../images/badge-up.png');}
.badge.down{background:linear-gradient(180deg,#7fdc37 0%, #3fb41d 100%) !important;}
.badge.down::before{background-image:url('../images/badge-down.png');}
.badge.flat{display:none !important;}
.badge.up::after,
.badge.down::after{
  content:"";
  position:absolute;
  inset:-6px;
  border-radius:999px;
  z-index:-1;
  filter:blur(12px);
  opacity:.65;
}
.badge.up::after{background:radial-gradient(circle,rgba(255,108,33,.36) 0%,rgba(255,108,33,.1) 55%,rgba(255,108,33,0) 78%);}
.badge.down::after{background:radial-gradient(circle,rgba(120,220,38,.35) 0%,rgba(120,220,38,.12) 55%,rgba(120,220,38,0) 78%);}
.price,
.price-tile .price,
.price-list .card .price{
  display:flex;
  align-items:flex-end;
  gap:6px;
  flex-wrap:wrap;
  line-height:1;
}
.price-value{font-weight:900;}
.price-unit,
.price-arrow{font-size:.62em;font-weight:900;line-height:1.1;}
.price-arrow{display:inline-flex;align-items:center;transform:translateY(-1px);}
.price.trend-up{color:#d92f2f !important;}
.price.trend-down{color:#1b8f46 !important;}
.price.trend-flat{color:#111827 !important;}
.price.textual{font-size:inherit;display:block;line-height:1.3;}
.price.textual.trend-flat,
.price.textual.trend-up,
.price.textual.trend-down{font-size:42px;font-weight:900;}
.price-list .card .price .price-value{font-size:1em;}
.price-list .card .price .price-unit,
.price-list .card .price .price-arrow{font-size:.56em;}
.price-tile .price .price-value{font-size:1em;}
.price-tile .price .price-unit,
.price-tile .price .price-arrow{font-size:.6em;}
@media (max-width:768px){
  .badge,
  .price-tile .badge,
  .price-list .card .badge{
    min-width:84px;
    height:34px !important;
    padding:0 12px 0 40px !important;
    font-size:13px !important;
  }
  .badge::before{left:7px;width:21px;height:21px;}
}
@media (max-width:420px){
  .badge,
  .price-tile .badge,
  .price-list .card .badge{
    min-width:76px;
    height:32px !important;
    padding:0 10px 0 36px !important;
    font-size:12px !important;
  }
  .badge::before{left:6px;width:20px;height:20px;}
}


/* ===== FINAL OVERRIDE: icon-only badge + colored text + price colors + info label ===== */

/* お知らせ卡片的分类标签不要拉满整行 */
.info-card a{
  display:block !important;
}
.info-card .info-label{
  display:inline-flex !important;
  width:auto !important;
  max-width:max-content !important;
  padding:6px 12px !important;
  line-height:1 !important;
}

/* 角标：去掉背景，只留图标 + 文字 */
.badge,
.price-tile .badge,
.price-list .card .badge{
  position:absolute !important;
  left:12px !important;
  top:12px !important;
  z-index:20 !important;

  display:inline-flex !important;
  align-items:center !important;
  justify-content:flex-start !important;

  width:auto !important;
  min-width:0 !important;
  height:32px !important;
  padding:0 0 0 38px !important;

  background:none !important;
  background-color:transparent !important;
  background-image:none !important;
  border:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;

  font-size:15px !important;
  font-weight:900 !important;
  line-height:1 !important;
  letter-spacing:.02em !important;
  text-indent:0 !important;
  white-space:nowrap !important;
  overflow:visible !important;
  filter:none !important;
  animation:none !important;
}

.badge::before,
.price-tile .badge::before,
.price-list .card .badge::before{
  content:"" !important;
  position:absolute !important;
  left:0 !important;
  top:50% !important;
  width:30px !important;
  height:30px !important;
  transform:translateY(-50%) !important;
  background-repeat:no-repeat !important;
  background-position:center !important;
  background-size:contain !important;
  filter:drop-shadow(0 5px 8px rgba(0,0,0,.16)) !important;
}

.badge::after,
.price-tile .badge::after,
.price-list .card .badge::after{
  display:none !important;
  content:none !important;
}

.badge.up{
  color:#d92f2f !important;
}
.badge.down{
  color:#138a45 !important;
}
.badge.flat{
  display:inline-flex !important;
  color:#111827 !important;
  padding-left:0 !important;
}

.badge.up::before{
  background-image:url('../images/badge-up.png') !important;
}
.badge.down::before{
  background-image:url('../images/badge-down.png') !important;
}
.badge.flat::before{
  display:none !important;
}

/* 图标保留轻微动效 */
.badge.up::before{
  animation:badgeFireMove 1.6s ease-in-out infinite !important;
}
.badge.down::before{
  animation:badgeDownMove 1.7s ease-in-out infinite !important;
}

@keyframes badgeFireMove{
  0%,100%{transform:translateY(-50%) scale(1);}
  50%{transform:translateY(calc(-50% - 3px)) scale(1.08);}
}
@keyframes badgeDownMove{
  0%,100%{transform:translateY(-50%) scale(1);}
  50%{transform:translateY(calc(-50% + 3px)) scale(1.06);}
}

/* 价格颜色：上升整组红色，下降整组绿色，普通黑色 */
.price.trend-up,
.price.trend-up *,
.price-list .card .price.trend-up,
.price-list .card .price.trend-up *,
.price-tile .price.trend-up,
.price-tile .price.trend-up *{
  color:#d92f2f !important;
}

.price.trend-down,
.price.trend-down *,
.price-list .card .price.trend-down,
.price-list .card .price.trend-down *,
.price-tile .price.trend-down,
.price-tile .price.trend-down *{
  color:#138a45 !important;
}

.price.trend-flat,
.price.trend-flat *,
.price-list .card .price.trend-flat,
.price-list .card .price.trend-flat *,
.price-tile .price.trend-flat,
.price-tile .price.trend-flat *{
  color:#111827 !important;
}

.price-arrow{
  font-size:.54em !important;
  margin-left:2px !important;
  transform:translateY(-1px) !important;
}

@media (max-width:768px){
  .badge,
  .price-tile .badge,
  .price-list .card .badge{
    left:10px !important;
    top:10px !important;
    height:30px !important;
    padding-left:34px !important;
    font-size:13px !important;
  }
  .badge::before,
  .price-tile .badge::before,
  .price-list .card .badge::before{
    width:27px !important;
    height:27px !important;
  }
}

@media (max-width:420px){
  .badge,
  .price-tile .badge,
  .price-list .card .badge{
    left:8px !important;
    top:8px !important;
    height:28px !important;
    padding-left:31px !important;
    font-size:12px !important;
  }
  .badge::before,
  .price-tile .badge::before,
  .price-list .card .badge::before{
    width:25px !important;
    height:25px !important;
  }
}


/* ===== FINAL USER FIX: only up/down badges, flat has no badge ===== */
.price-list .card,
.price-tile{overflow:hidden;}

.price-list .card .badge,
.price-tile .badge,
.badge{
  position:absolute !important;
  top:12px !important;
  left:12px !important;
  z-index:30 !important;
  display:inline-flex !important;
  align-items:center !important;
  gap:6px !important;
  width:auto !important;
  min-width:0 !important;
  height:30px !important;
  padding:0 0 0 34px !important;
  background:transparent !important;
  border:none !important;
  border-radius:0 !important;
  box-shadow:none !important;
  font-size:14px !important;
  font-weight:900 !important;
  line-height:1 !important;
  letter-spacing:.02em !important;
  white-space:nowrap !important;
}
.price-list .card .badge::before,
.price-tile .badge::before,
.badge::before{
  content:'' !important;
  position:absolute !important;
  left:0 !important;
  top:50% !important;
  width:28px !important;
  height:28px !important;
  transform:translateY(-50%) !important;
  background-repeat:no-repeat !important;
  background-position:center !important;
  background-size:contain !important;
}
.price-list .card .badge::after,
.price-tile .badge::after,
.badge::after{content:none !important; display:none !important;}
.badge.up{color:#d92f2f !important;}
.badge.down{color:#138a45 !important;}
.badge.up::before{background-image:url('../images/badge-up.png') !important; filter:drop-shadow(0 3px 6px rgba(220,80,20,.25)); animation:badgeFireMove 1.6s ease-in-out infinite !important;}
.badge.down::before{background-image:url('../images/badge-down.png') !important; filter:drop-shadow(0 3px 6px rgba(20,138,69,.25)); animation:badgeDownMove 1.7s ease-in-out infinite !important;}
.badge.flat{display:none !important;}

.price.trend-up, .price.trend-up *, .price-list .card .price.trend-up, .price-list .card .price.trend-up *{color:#d92f2f !important;}
.price.trend-down, .price.trend-down *, .price-list .card .price.trend-down, .price-list .card .price.trend-down *{color:#138a45 !important;}
.price.trend-flat, .price.trend-flat *, .price-list .card .price.trend-flat, .price-list .card .price.trend-flat *{color:#111827 !important;}
.price-arrow{font-size:.56em !important; margin-left:4px !important; display:inline-flex !important; align-items:center !important; transform:translateY(-1px) !important;}

.info-card a,
.detail-article{
  display:flex !important;
  flex-direction:column !important;
  align-items:flex-start !important;
}
.info-card .info-label,
.detail-article .info-label,
.home-news-card .info-label{
  display:inline-flex !important;
  width:fit-content !important;
  max-width:max-content !important;
  flex:none !important;
  align-self:flex-start !important;
  padding:6px 12px !important;
  border-radius:999px !important;
}

@media (max-width:768px){
  .price-list .card .badge,
  .price-tile .badge,
  .badge{top:10px !important; left:10px !important; padding-left:30px !important; font-size:13px !important;}
  .price-list .card .badge::before,
  .price-tile .badge::before,
  .badge::before{width:24px !important; height:24px !important;}
}


/* ===== home price final fix: normal/textual cards no badge ===== */
.price-tile:has(.price.trend-flat) .badge,
.price-tile:has(.price.textual) .badge,
.price-list .card:has(.price.trend-flat) .badge,
.price-list .card:has(.price.textual) .badge{
  display:none !important;
}

.price.textual.trend-flat,
.price-tile .price.textual.trend-flat,
.price-list .card .price.textual.trend-flat{
  color:#111827 !important;
}


/* ===== BADGE OVERLAY ICON VERSION: bigger icon + text on top + stronger motion ===== */
.price-list .card,
.price-tile{
  overflow:hidden;
}

.price-list .card .badge,
.price-tile .badge,
.badge{
  position:absolute !important;
  left:12px !important;
  top:10px !important;
  z-index:40 !important;

  display:flex !important;
  align-items:flex-start !important;
  justify-content:center !important;

  width:74px !important;
  height:60px !important;
  min-width:74px !important;
  padding:4px 0 0 0 !important;
  margin:0 !important;

  background:none !important;
  background-color:transparent !important;
  border:none !important;
  border-radius:0 !important;
  box-shadow:none !important;

  font-size:16px !important;
  font-weight:900 !important;
  line-height:1 !important;
  letter-spacing:.01em !important;
  text-indent:0 !important;
  white-space:nowrap !important;
  overflow:visible !important;

  transform-origin:center center !important;
  animation:trendBadgeFloat 2.1s ease-in-out infinite !important;
}

.price-list .card .badge::before,
.price-tile .badge::before,
.badge::before{
  content:'' !important;
  position:absolute !important;
  left:50% !important;
  top:4px !important;
  width:54px !important;
  height:54px !important;
  transform:translateX(-50%) !important;
  background-repeat:no-repeat !important;
  background-position:center !important;
  background-size:contain !important;
  z-index:-1 !important;
}

.price-list .card .badge::after,
.price-tile .badge::after,
.badge::after{
  content:'' !important;
  position:absolute !important;
  left:50% !important;
  top:8px !important;
  width:42px !important;
  height:42px !important;
  transform:translateX(-50%) !important;
  border-radius:999px !important;
  filter:blur(10px) !important;
  opacity:.45 !important;
  z-index:-2 !important;
}

.badge.up,
.price-list .card .badge.up,
.price-tile .badge.up{
  color:#d92f2f !important;
  text-shadow:0 1px 0 rgba(255,255,255,.85), 0 0 8px rgba(255,121,55,.35) !important;
}
.badge.down,
.price-list .card .badge.down,
.price-tile .badge.down{
  color:#138a45 !important;
  text-shadow:0 1px 0 rgba(255,255,255,.8), 0 0 8px rgba(98,219,65,.30) !important;
}
.badge.flat,
.price-list .card .badge.flat,
.price-tile .badge.flat{
  display:none !important;
}

.badge.up::before,
.price-list .card .badge.up::before,
.price-tile .badge.up::before{
  background-image:url('../images/badge-up.png') !important;
  filter:drop-shadow(0 6px 12px rgba(255,110,28,.35)) !important;
  animation:badgeFirePulse 1.45s ease-in-out infinite !important;
}
.badge.down::before,
.price-list .card .badge.down::before,
.price-tile .badge.down::before{
  background-image:url('../images/badge-down.png') !important;
  filter:drop-shadow(0 6px 12px rgba(72,190,45,.30)) !important;
  animation:badgeArrowDropStrong 1.55s ease-in-out infinite !important;
}

.badge.up::after,
.price-list .card .badge.up::after,
.price-tile .badge.up::after{
  background:radial-gradient(circle, rgba(255,124,42,.40) 0%, rgba(255,124,42,.18) 50%, rgba(255,124,42,0) 76%) !important;
  animation:badgeGlowPulse 1.45s ease-in-out infinite !important;
}
.badge.down::after,
.price-list .card .badge.down::after,
.price-tile .badge.down::after{
  background:radial-gradient(circle, rgba(110,225,58,.38) 0%, rgba(110,225,58,.16) 50%, rgba(110,225,58,0) 76%) !important;
  animation:badgeGlowPulse 1.55s ease-in-out infinite !important;
}

@keyframes trendBadgeFloat{
  0%,100%{ transform:translateY(0) scale(1); }
  50%{ transform:translateY(-2px) scale(1.02); }
}
@keyframes badgeFirePulse{
  0%,100%{ transform:translateX(-50%) scale(1) rotate(-2deg); }
  50%{ transform:translateX(-50%) translateY(-3px) scale(1.10) rotate(2deg); }
}
@keyframes badgeArrowDropStrong{
  0%,100%{ transform:translateX(-50%) translateY(0) scale(1); }
  50%{ transform:translateX(-50%) translateY(3px) scale(1.10); }
}
@keyframes badgeGlowPulse{
  0%,100%{ opacity:.38; transform:translateX(-50%) scale(1); }
  50%{ opacity:.62; transform:translateX(-50%) scale(1.08); }
}

@media (max-width:768px){
  .price-list .card .badge,
  .price-tile .badge,
  .badge{
    left:10px !important;
    top:8px !important;
    width:68px !important;
    min-width:68px !important;
    height:54px !important;
    padding-top:3px !important;
    font-size:15px !important;
  }
  .price-list .card .badge::before,
  .price-tile .badge::before,
  .badge::before{
    width:48px !important;
    height:48px !important;
    top:3px !important;
  }
  .price-list .card .badge::after,
  .price-tile .badge::after,
  .badge::after{
    width:38px !important;
    height:38px !important;
    top:8px !important;
  }
}

@media (max-width:420px){
  .price-list .card .badge,
  .price-tile .badge,
  .badge{
    left:8px !important;
    top:7px !important;
    width:62px !important;
    min-width:62px !important;
    height:50px !important;
    font-size:14px !important;
  }
  .price-list .card .badge::before,
  .price-tile .badge::before,
  .badge::before{
    width:44px !important;
    height:44px !important;
  }
  .price-list .card .badge::after,
  .price-tile .badge::after,
  .badge::after{
    width:34px !important;
    height:34px !important;
  }
}

/* ===== white centered badge text override ===== */
.price-list .card .badge,
.price-tile .badge,
.badge{
  justify-content:center !important;
  align-items:flex-start !important;
  text-align:center !important;
  color:#ffffff !important;
  text-shadow:0 1px 2px rgba(0,0,0,.45), 0 0 8px rgba(0,0,0,.18) !important;
}
.badge.up,
.price-list .card .badge.up,
.price-tile .badge.up,
.badge.down,
.price-list .card .badge.down,
.price-tile .badge.down{
  color:#ffffff !important;
}


/* ===== badge final position fix: centered white text, lowered for readability ===== */
.price-list .card .badge,
.price-tile .badge,
.badge{
  left:14px !important;
  top:14px !important;
  width:82px !important;
  min-width:82px !important;
  height:72px !important;
  padding:10px 0 0 0 !important;
  display:flex !important;
  justify-content:center !important;
  align-items:flex-start !important;
  text-align:center !important;
  font-size:17px !important;
  font-weight:900 !important;
  line-height:1.05 !important;
  color:#fff !important;
  white-space:nowrap !important;
  text-shadow:0 1px 2px rgba(0,0,0,.55), 0 0 10px rgba(0,0,0,.25) !important;
}
.price-list .card .badge::before,
.price-tile .badge::before,
.badge::before{
  top:8px !important;
  width:58px !important;
  height:58px !important;
}
.price-list .card .badge::after,
.price-tile .badge::after,
.badge::after{
  top:14px !important;
  width:46px !important;
  height:46px !important;
}
.badge.up,
.price-list .card .badge.up,
.price-tile .badge.up,
.badge.down,
.price-list .card .badge.down,
.price-tile .badge.down{
  color:#fff !important;
}
@media (max-width:768px){
  .price-list .card .badge,
  .price-tile .badge,
  .badge{
    left:12px !important;
    top:12px !important;
    width:76px !important;
    min-width:76px !important;
    height:66px !important;
    padding-top:9px !important;
    font-size:16px !important;
  }
  .price-list .card .badge::before,
  .price-tile .badge::before,
  .badge::before{
    top:7px !important;
    width:54px !important;
    height:54px !important;
  }
  .price-list .card .badge::after,
  .price-tile .badge::after,
  .badge::after{
    top:13px !important;
    width:42px !important;
    height:42px !important;
  }
}
@media (max-width:420px){
  .price-list .card .badge,
  .price-tile .badge,
  .badge{
    left:10px !important;
    top:10px !important;
    width:72px !important;
    min-width:72px !important;
    height:62px !important;
    padding-top:8px !important;
    font-size:15px !important;
  }
  .price-list .card .badge::before,
  .price-tile .badge::before,
  .badge::before{
    top:6px !important;
    width:50px !important;
    height:50px !important;
  }
  .price-list .card .badge::after,
  .price-tile .badge::after,
  .badge::after{
    top:12px !important;
    width:38px !important;
    height:38px !important;
  }
}


/* ===== v4 enhanced trend badge: centered white text, lowered position, stronger animation ===== */
.price-list .card .badge,
.price-tile .badge,
.badge{
  position:absolute !important;
  left:12px !important;
  top:12px !important;
  width:88px !important;
  min-width:88px !important;
  height:78px !important;
  padding-top:4px !important;
  display:block !important;
  text-align:center !important;
  font-size:18px !important;
  font-weight:900 !important;
  line-height:1 !important;
  letter-spacing:0 !important;
  color:#fff !important;
  white-space:nowrap !important;
  text-shadow:0 2px 6px rgba(0,0,0,.68), 0 0 12px rgba(0,0,0,.25) !important;
  z-index:45 !important;
  animation:trendBadgeFloatStrong 2s ease-in-out infinite !important;
}
.price-list .card .badge::before,
.price-tile .badge::before,
.badge::before{
  content:'' !important;
  position:absolute !important;
  left:50% !important;
  top:14px !important;
  width:62px !important;
  height:62px !important;
  transform:translateX(-50%) !important;
  background-repeat:no-repeat !important;
  background-position:center !important;
  background-size:contain !important;
  z-index:-1 !important;
}
.price-list .card .badge::after,
.price-tile .badge::after,
.badge::after{
  content:'' !important;
  position:absolute !important;
  left:50% !important;
  top:22px !important;
  width:48px !important;
  height:48px !important;
  transform:translateX(-50%) !important;
  border-radius:999px !important;
  filter:blur(12px) !important;
  opacity:.58 !important;
  z-index:-2 !important;
}
.badge.up,
.price-list .card .badge.up,
.price-tile .badge.up,
.badge.down,
.price-list .card .badge.down,
.price-tile .badge.down{
  color:#fff !important;
}
.badge.up::before,
.price-list .card .badge.up::before,
.price-tile .badge.up::before{
  background-image:url('../images/badge-up.png') !important;
  filter:drop-shadow(0 8px 14px rgba(255,110,28,.42)) !important;
  animation:badgeFirePulseStrong 1.25s ease-in-out infinite !important;
}
.badge.down::before,
.price-list .card .badge.down::before,
.price-tile .badge.down::before{
  background-image:url('../images/badge-down.png') !important;
  filter:drop-shadow(0 8px 14px rgba(72,190,45,.38)) !important;
  animation:badgeArrowDropBounce 1.4s ease-in-out infinite !important;
}
.badge.up::after,
.price-list .card .badge.up::after,
.price-tile .badge.up::after{
  background:radial-gradient(circle, rgba(255,124,42,.52) 0%, rgba(255,124,42,.20) 48%, rgba(255,124,42,0) 74%) !important;
  animation:badgeGlowPulseStrong 1.25s ease-in-out infinite !important;
}
.badge.down::after,
.price-list .card .badge.down::after,
.price-tile .badge.down::after{
  background:radial-gradient(circle, rgba(110,225,58,.48) 0%, rgba(110,225,58,.18) 48%, rgba(110,225,58,0) 74%) !important;
  animation:badgeGlowPulseStrong 1.4s ease-in-out infinite !important;
}
@keyframes trendBadgeFloatStrong{
  0%,100%{ transform:translateY(0) scale(1); }
  50%{ transform:translateY(-3px) scale(1.035); }
}
@keyframes badgeFirePulseStrong{
  0%,100%{ transform:translateX(-50%) scale(1) rotate(-2deg); }
  35%{ transform:translateX(-50%) translateY(-2px) scale(1.08) rotate(1deg); }
  70%{ transform:translateX(-50%) translateY(-4px) scale(1.13) rotate(3deg); }
}
@keyframes badgeArrowDropBounce{
  0%,100%{ transform:translateX(-50%) translateY(0) scale(1); }
  45%{ transform:translateX(-50%) translateY(5px) scale(1.10); }
  70%{ transform:translateX(-50%) translateY(2px) scale(1.04); }
}
@keyframes badgeGlowPulseStrong{
  0%,100%{ opacity:.48; transform:translateX(-50%) scale(1); }
  50%{ opacity:.78; transform:translateX(-50%) scale(1.14); }
}
@media (max-width:768px){
  .price-list .card .badge,
  .price-tile .badge,
  .badge{
    left:10px !important;
    top:10px !important;
    width:82px !important;
    min-width:82px !important;
    height:72px !important;
    padding-top:4px !important;
    font-size:17px !important;
  }
  .price-list .card .badge::before,
  .price-tile .badge::before,
  .badge::before{
    top:13px !important;
    width:58px !important;
    height:58px !important;
  }
  .price-list .card .badge::after,
  .price-tile .badge::after,
  .badge::after{
    top:20px !important;
    width:44px !important;
    height:44px !important;
  }
}

/* ===== final compact home price badge fix ===== */
.price-tile .badge{
  left:7px !important;
  top:2px !important;
  width:58px !important;
  min-width:58px !important;
  height:58px !important;
  padding:12px 0 0 !important;
  font-size:13px !important;
  line-height:1 !important;
  z-index:6 !important;
}
.price-tile .badge::before{
  top:6px !important;
  width:48px !important;
  height:48px !important;
}
.price-tile .badge::after{
  top:11px !important;
  width:38px !important;
  height:38px !important;
}
@media (max-width:420px){
  .price-tile .badge{
    left:8px !important;
    top:5px !important;
    width:56px !important;
    min-width:56px !important;
    height:56px !important;
    padding-top:12px !important;
    font-size:12px !important;
  }
  .price-tile .badge::before{
    top:6px !important;
    width:46px !important;
    height:46px !important;
  }
  .price-tile .badge::after{
    top:11px !important;
    width:36px !important;
    height:36px !important;
  }
}

/* ===== final carousel arrow vertical center fix ===== */
.banner.banner-full.special-carousel > .special-carousel-btn{
  top:50% !important;
  bottom:auto !important;
  margin:0 !important;
  padding:0 0 3px !important;
  transform:translateY(-50%) !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  line-height:1 !important;
}
.banner.banner-full.special-carousel > .special-carousel-btn.prev{
  left:14px !important;
}
.banner.banner-full.special-carousel > .special-carousel-btn.next{
  right:14px !important;
}
@media (max-width:768px){
  .banner.banner-full.special-carousel > .special-carousel-btn.prev{
    left:10px !important;
  }
  .banner.banner-full.special-carousel > .special-carousel-btn.next{
    right:10px !important;
  }
}

/* ===== actual final home price card polish ===== */
.price-tile{
  grid-template-columns:104px minmax(0,1fr) !important;
}
.price-tile img{
  width:104px !important;
  height:104px !important;
}
.price-tile .badge{
  padding-top:18px !important;
}
.price-tile .price.textual.trend-flat,
.price-tile .price.textual{
  font-size:32px !important;
  line-height:1.15 !important;
}
@media (max-width:768px){
  .price-tile{
    grid-template-columns:108px minmax(0,1fr) !important;
    gap:18px !important;
  }
  .price-tile img{
    width:108px !important;
    height:108px !important;
  }
  .price-tile .price.textual.trend-flat,
  .price-tile .price.textual{
    font-size:30px !important;
  }
}
@media (max-width:420px){
  .price-tile{
    grid-template-columns:96px minmax(0,1fr) !important;
  }
  .price-tile img{
    width:96px !important;
    height:96px !important;
  }
  .price-tile .badge{
    padding-top:17px !important;
  }
  .price-tile .price.textual.trend-flat,
  .price-tile .price.textual{
    font-size:27px !important;
  }
}

/* ===== separate up badge tuning: home tiles ===== */
.price-tile .badge.up{
  left:8px !important;
  top:4px !important;
  width:58px !important;
  min-width:58px !important;
  height:58px !important;
  padding-top:18px !important;
  font-size:13px !important;
  line-height:1 !important;
}
.price-tile .badge.up::before{
  top:6px !important;
  width:48px !important;
  height:48px !important;
}
.price-tile .badge.up::after{
  top:11px !important;
  width:38px !important;
  height:38px !important;
}

/* ===== separate up badge tuning: price list cards ===== */
.price-list .card .badge.up{
  left:12px !important;
  top:12px !important;
  width:68px !important;
  min-width:68px !important;
  height:68px !important;
  padding-top:20px !important;
  font-size:14px !important;
  line-height:1 !important;
}
.price-list .card .badge.up::before{
  top:7px !important;
  width:56px !important;
  height:56px !important;
}
.price-list .card .badge.up::after{
  top:13px !important;
  width:44px !important;
  height:44px !important;
}
@media (max-width:768px){
  .price-list .card .badge.up{
    left:12px !important;
    top:12px !important;
    width:64px !important;
    min-width:64px !important;
    height:64px !important;
    padding-top:19px !important;
    font-size:13px !important;
  }
  .price-list .card .badge.up::before{
    top:7px !important;
    width:52px !important;
    height:52px !important;
  }
  .price-list .card .badge.up::after{
    top:12px !important;
    width:40px !important;
    height:40px !important;
  }
}

/* ===== absolute final swap home price/title and animate flow halos ===== */
.price-tile > div{
  display:flex !important;
  flex-direction:column !important;
  align-items:flex-start !important;
}
.price-tile h3{
  order:2 !important;
  margin:8px 0 0 !important;
}
.price-tile .price{
  order:1 !important;
  margin-top:0 !important;
}
.home-flow-visual .step::before{
  z-index:2 !important;
  animation:homeFlowDotPulseAbsolute 1.8s ease-in-out infinite !important;
}
.home-flow-visual .step::after{
  content:"" !important;
  position:absolute !important;
  left:50% !important;
  top:0 !important;
  width:48px !important;
  height:48px !important;
  border-radius:999px !important;
  transform:translateX(-50%) !important;
  background:rgba(217,47,47,.25) !important;
  animation:homeFlowHaloPulseAbsolute 1.8s ease-out infinite !important;
  z-index:1 !important;
}
@keyframes homeFlowDotPulseAbsolute{
  0%,100%{box-shadow:0 0 0 8px rgba(217,47,47,.16),0 12px 28px rgba(0,0,0,.28)}
  50%{box-shadow:0 0 0 13px rgba(217,47,47,.24),0 16px 34px rgba(0,0,0,.34)}
}
@keyframes homeFlowHaloPulseAbsolute{
  0%{opacity:.78; transform:translateX(-50%) scale(1)}
  70%{opacity:0; transform:translateX(-50%) scale(1.85)}
  100%{opacity:0; transform:translateX(-50%) scale(1.85)}
}
@media (max-width:1024px){
  .home-flow-visual .step::after{
    left:20px !important;
    top:20px !important;
    transform:none !important;
  }
  @keyframes homeFlowHaloPulseAbsolute{
    0%{opacity:.78; transform:scale(1)}
    70%{opacity:0; transform:scale(1.85)}
    100%{opacity:0; transform:scale(1.85)}
  }
}

/* ===== 20260628 H5 responsive and structure update ===== */
html{
  scroll-behavior:smooth;
}

.reason-grid{
  align-items:stretch;
}
.reason-card{
  position:relative;
  overflow:hidden;
  padding:30px 28px 28px !important;
  border-radius:18px !important;
  background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
  border:1px solid #dce5f1;
}
.reason-card::before{
  content:"";
  position:absolute;
  inset:0 0 auto;
  height:4px;
  background:linear-gradient(90deg,var(--red),#f2c46d);
}
.reason-icon{
  width:54px;
  height:54px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:18px;
  border-radius:16px;
  background:#fff2f2;
  color:var(--red);
  font-weight:900;
  font-size:24px;
  box-shadow:inset 0 0 0 1px rgba(217,47,47,.12),0 10px 24px rgba(16,35,70,.08);
}
.reason-card h3{
  color:#0b2345;
  font-size:24px;
}
.reason-card p{
  line-height:1.9;
}

.price-filter-toggle{
  display:none;
  width:100%;
  border:0;
  border-radius:14px;
  background:#0b2345;
  color:#fff;
  padding:16px 18px;
  font-weight:900;
  text-align:left;
  cursor:pointer;
}
.price-filter-toggle::after{
  content:"";
  float:right;
  width:10px;
  height:10px;
  margin-top:8px;
  border-right:2px solid #fff;
  border-bottom:2px solid #fff;
  transform:rotate(45deg);
  transition:transform .2s ease;
}
.price-filter-toggle[aria-expanded="true"]::after{
  transform:rotate(225deg);
  margin-top:12px;
}

.contact-layout,
.contact-layout main,
.form,
.form-grid,
.field,
.field input,
.field textarea,
.field select{
  min-width:0;
}
.field input,
.field textarea,
.field select,
.form button{
  max-width:100%;
}

.area-block{
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
}

.company-table dd{
  min-width:0;
  overflow-wrap:anywhere;
}

.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .55s ease,transform .55s ease,box-shadow .2s ease,border-color .2s ease;
  transition-delay:var(--reveal-delay,0ms);
}
.reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}
.card,
.price-tile,
.btn{
  will-change:transform;
}
.card:hover,
.price-tile:hover{
  transform:translateY(-3px);
  border-color:#cbd7e8;
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .reveal,
  .reveal.is-visible{
    opacity:1;
    transform:none;
    transition:none;
  }
  .card,
  .price-tile,
  .btn{
    will-change:auto;
  }
}

@media (max-width:768px){
  body{
    overflow-x:hidden;
  }
  .hero-cover{
    min-height:320px !important;
    align-items:flex-end;
  }
  .hero-cover::before{
    background-image:linear-gradient(180deg,rgba(8,16,29,.12) 0%,rgba(8,16,29,.34) 42%,rgba(8,16,29,.86) 100%),url('../images/home-hero-banner.png') !important;
    background-position:66% center !important;
    background-size:cover !important;
  }
  .hero-cover-copy{
    padding:93px 0 20px !important;
  }
  .hero-cover h1{
    font-size:38px !important;
  }
  .hero-cover .hero-actions{
    gap:10px;
  }

  .price-side{
    width:100%;
    position:static !important;
  }
  .price-filter-toggle{
    display:block;
  }
  .price-filter-panel{
    display:none;
    margin-top:10px;
    overflow:hidden;
    border-radius:14px;
    border:1px solid #e1e7f0;
    background:#fff;
  }
  .price-filter-panel.open{
    display:block;
  }
  .price-filter-panel h3{
    border-radius:0 !important;
  }
  .price-side .side-tools{
    display:none !important;
  }
  .searchbar{
    margin-top:0;
  }

  .contact-layout{
    width:100%;
    display:grid;
    grid-template-columns:minmax(0,1fr) !important;
    gap:18px;
  }
  .contact-side,
  .contact-layout main,
  .form{
    width:100%;
    max-width:100%;
  }
  .contact-side a,
  .contact-side .contact-meta{
    word-break:break-word;
  }
  .form{
    padding:20px 16px !important;
    border-radius:18px !important;
  }
  .form-grid{
    grid-template-columns:minmax(0,1fr) !important;
    gap:14px !important;
  }
  .field input,
  .field textarea,
  .field select{
    width:100%;
  }
  .field textarea{
    min-height:150px;
  }

  .area-stack{
    gap:22px;
  }
  .area-block,
  .area-block.reverse{
    display:grid;
    grid-template-columns:minmax(0,1fr) !important;
    gap:14px;
  }
  .area-info{
    padding:22px 18px !important;
    border-radius:18px !important;
  }
  .area-info h2{
    font-size:28px !important;
  }
  .area-info .tel{
    font-size:30px !important;
    overflow-wrap:anywhere;
  }
  .map-card,
  .map-card iframe{
    min-height:260px !important;
    border-radius:18px !important;
  }

  .company-main .card.reason{
    padding:22px 18px !important;
  }
  .company-table{
    gap:10px !important;
  }
  .company-table dl{
    display:block !important;
    padding:14px 0 !important;
  }
  .company-table dt{
    display:block;
    margin-bottom:6px;
    color:var(--red);
    font-size:13px;
    letter-spacing:.04em;
  }
  .company-table dd{
    margin:0;
    color:#0b2345;
    font-size:16px;
    line-height:1.8;
  }

  .reason-card{
    padding:24px 20px !important;
  }
  .reason-card h3{
    font-size:21px;
  }
}

/* ===== 20260628 recruit page ===== */
.recruit-hero{
  position:relative;
  overflow:hidden;
  background:#0b2345;
  color:#fff;
}
.recruit-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,rgba(11,35,69,.94) 0%,rgba(11,35,69,.84) 46%,rgba(11,35,69,.48) 100%),
    url('../images/page-yard.jpg');
  background-size:cover;
  background-position:center right;
}
.recruit-hero-inner{
  position:relative;
  z-index:2;
  min-height:520px;
  display:grid;
  grid-template-columns:minmax(0,1fr) 340px;
  gap:34px;
  align-items:center;
}
.recruit-hero-copy{
  max-width:780px;
  padding:84px 0;
}
.recruit-hero .crumb{
  color:#ff7770;
}
.recruit-hero h1{
  margin:16px 0 18px;
  font-size:52px;
  line-height:1.18;
  letter-spacing:0;
}
.recruit-hero p{
  max-width:700px;
  margin:0;
  color:rgba(255,255,255,.86);
  font-size:18px;
}
.recruit-hero-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:28px;
}
.recruit-hero-panel{
  padding:28px;
  border-radius:18px;
  background:rgba(255,255,255,.94);
  color:#0b2345;
  box-shadow:0 18px 40px rgba(0,0,0,.22);
  display:grid;
  gap:8px;
}
.recruit-hero-panel b{
  color:var(--red);
  font-size:14px;
}
.recruit-hero-panel strong{
  font-size:34px;
  line-height:1.1;
}
.recruit-hero-panel span{
  color:#5f6673;
  font-weight:700;
}
.recruit-points{
  margin-top:-18px;
}
.recruit-point{
  padding:28px;
  border-radius:18px;
  border-color:#dce5f1;
}
.recruit-point span{
  display:inline-flex;
  margin-bottom:18px;
  color:var(--red);
  font-weight:900;
  letter-spacing:.08em;
}
.recruit-point h3{
  margin:0 0 10px;
  color:#0b2345;
  font-size:24px;
}
.recruit-point p{
  margin:0;
  color:#5f6673;
}
.recruit-jobs{
  display:grid;
  gap:22px;
}
.recruit-job{
  padding:28px;
  border-radius:20px;
}
.recruit-job-head{
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:flex-start;
  margin-bottom:14px;
}
.job-type{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:5px 12px;
  border-radius:999px;
  background:#fff2f2;
  color:var(--red);
  font-weight:900;
  font-size:13px;
}
.recruit-job h3{
  margin:10px 0 0;
  font-size:30px;
  color:#0b2345;
}
.job-summary{
  margin:0 0 18px;
  color:#5f6673;
  font-size:16px;
}
.job-meta{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  margin-bottom:22px;
}
.job-meta dl{
  margin:0;
  padding:16px;
  border-radius:14px;
  background:#f6f8fb;
  border:1px solid #e1e7f0;
}
.job-meta dt{
  color:var(--red);
  font-size:13px;
  font-weight:900;
}
.job-meta dd{
  margin:5px 0 0;
  color:#0b2345;
  font-weight:800;
  white-space:pre-line;
}
.job-detail-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.job-detail-grid section{
  min-width:0;
}
.job-detail-grid h4{
  margin:0 0 8px;
  color:#0b2345;
  font-size:18px;
}
.job-detail-grid p,
.job-note{
  margin:0;
  color:#5f6673;
  white-space:pre-line;
}
.job-note{
  margin-top:18px;
  padding:14px 16px;
  border-radius:14px;
  background:#fff8e6;
  border:1px solid #ead191;
  color:#6f5730;
}
.recruit-empty{
  padding:30px;
}
.recruit-flow-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
}
.recruit-flow-grid div{
  padding:22px;
  border-radius:18px;
  background:#fff;
  border:1px solid #e1e7f0;
  box-shadow:var(--shadow);
}
.recruit-flow-grid span{
  color:var(--red);
  font-weight:900;
  font-size:13px;
}
.recruit-flow-grid h3{
  margin:8px 0 8px;
  color:#0b2345;
}
.recruit-flow-grid p{
  margin:0;
  color:#5f6673;
}
.recruit-notice{
  margin-top:24px;
  padding:24px 26px;
  border-radius:18px;
  background:#0b2345;
  color:#fff;
}
.recruit-notice h3{
  margin:0 0 8px;
}
.recruit-notice p{
  margin:0;
  color:rgba(255,255,255,.84);
}
@media (max-width:1024px){
  .recruit-hero-inner{
    grid-template-columns:1fr;
  }
  .recruit-hero-panel{
    margin-bottom:42px;
  }
  .job-meta,
  .job-detail-grid,
  .recruit-flow-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media (max-width:768px){
  .recruit-hero::before{
    background:
      linear-gradient(180deg,rgba(11,35,69,.34) 0%,rgba(11,35,69,.74) 48%,rgba(11,35,69,.96) 100%),
      url('../images/page-yard.jpg');
    background-size:cover;
    background-position:64% center;
  }
  .recruit-hero-inner{
    min-height:auto;
    gap:18px;
  }
  .recruit-hero-copy{
    padding:58px 0 10px;
  }
  .recruit-hero h1{
    font-size:36px;
  }
  .recruit-hero p{
    font-size:16px;
  }
  .recruit-hero-actions,
  .recruit-job-head{
    display:grid;
    grid-template-columns:1fr;
  }
  .recruit-hero-panel{
    margin-bottom:34px;
    padding:22px;
  }
  .recruit-hero-panel strong{
    font-size:28px;
  }
  .job-meta,
  .job-detail-grid,
  .recruit-flow-grid{
    grid-template-columns:1fr;
  }
  .recruit-job{
    padding:22px 18px;
  }
  .recruit-job h3{
    font-size:25px;
  }
}

/* ===== 20260628 recruit adjustment ===== */
.recruit-hero-inner{
  min-height:300px !important;
  grid-template-columns:minmax(0,1fr) 300px !important;
}
.recruit-hero-copy{
  padding:46px 0 !important;
}
.recruit-hero h1{
  font-size:42px !important;
  max-width:760px;
}
.recruit-hero p{
  font-size:16px !important;
  max-width:720px;
}
.recruit-hero-panel{
  padding:22px 24px !important;
  border-radius:16px !important;
}
.recruit-hero-panel strong{
  font-size:30px !important;
}
.recruit-intro,
.recruit-flow{
  display:none !important;
}
@media (max-width:1024px){
  .recruit-hero-inner{
    grid-template-columns:1fr !important;
    min-height:300px !important;
  }
  .recruit-hero-panel{
    display:none !important;
  }
}
@media (max-width:768px){
  .recruit-hero-inner{
    min-height:260px !important;
  }
  .recruit-hero-copy{
    padding:38px 0 !important;
  }
  .recruit-hero h1{
    font-size:34px !important;
  }
  .recruit-hero-actions{
    margin-top:18px !important;
  }
}

/* ===== 20260628 price detail / line page ===== */
.recruit-hero{
  height:300px !important;
  min-height:300px !important;
}
.recruit-hero-inner{
  height:300px !important;
  min-height:300px !important;
}
.recruit-hero-copy{
  padding:34px 0 !important;
}
.recruit-hero h1{
  font-size:38px !important;
}
.recruit-hero-panel{
  transform:scale(.92);
  transform-origin:center right;
}
.article-motion{
  position:relative;
  transition:transform .32s ease,box-shadow .32s ease,border-color .32s ease;
}
.article-motion::after{
  content:"";
  position:absolute;
  left:18px;
  right:18px;
  bottom:-1px;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--red),#f0c46c);
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .32s ease;
}
.article-motion:hover{
  transform:translateY(-4px);
  box-shadow:0 14px 32px rgba(16,35,70,.12);
}
.article-motion:hover::after{
  transform:scaleX(1);
}
.price-card-link{
  display:flex;
  gap:18px;
  width:100%;
  color:inherit;
}
.price-list .card .price-card-link{
  display:block;
}
.price-detail-wrap{
  display:grid;
  grid-template-columns:minmax(0,1fr) 420px;
  gap:26px;
  align-items:start;
}
.price-gallery{
  padding:0;
  overflow:hidden;
}
.price-gallery-main{
  width:100%;
  height:420px;
  object-fit:cover;
  border-bottom:1px solid var(--line);
}
.price-gallery-thumbs{
  display:flex;
  gap:10px;
  padding:12px;
  overflow:auto;
}
.price-gallery-thumbs button{
  width:96px;
  height:72px;
  flex:0 0 96px;
  padding:0;
  border:2px solid transparent;
  border-radius:8px;
  background:#fff;
  overflow:hidden;
  cursor:pointer;
}
.price-gallery-thumbs button.active{
  border-color:var(--red);
}
.price-gallery-thumbs img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.price-detail-card{
  padding:28px;
}
.price-date{
  font-size:18px;
  font-weight:800;
  color:#111827;
  margin-bottom:8px;
}
.price-detail-value{
  display:flex;
  align-items:flex-end;
  gap:10px;
  color:var(--red);
  line-height:1;
}
.price-detail-value strong{
  font-size:58px;
  font-weight:900;
  letter-spacing:.02em;
}
.price-detail-value span{
  color:#111827;
  font-size:24px;
  font-weight:900;
  padding-bottom:8px;
}
.tax-note{
  margin:8px 0 22px;
  color:#111827;
  font-weight:800;
}
.price-detail-actions{
  display:grid;
  gap:12px;
}
.price-detail-notes .card{
  padding:28px;
}
.price-detail-notes h2{
  margin:0 0 12px;
  color:#0b2345;
}
.price-detail-notes ol{
  padding-left:22px;
  color:#333;
}
.price-detail-notes li+li{
  margin-top:10px;
}
.line-layout{
  display:grid;
  grid-template-columns:420px minmax(0,1fr);
  gap:26px;
  align-items:start;
}
.line-guide{
  padding:30px;
  border-radius:20px;
}
.line-guide h2{
  margin:10px 0 12px;
  font-size:32px;
  color:#0b2345;
}
.line-guide p{
  margin:0;
  color:#5f6673;
}
.line-steps{
  display:grid;
  gap:12px;
  margin:24px 0;
}
.line-steps div{
  display:flex;
  align-items:center;
  gap:12px;
  padding:14px;
  border-radius:14px;
  background:#f6f8fb;
  border:1px solid #e1e7f0;
}
.line-steps b{
  color:var(--red);
}
.line-callout{
  display:grid;
  gap:4px;
  padding:18px;
  border-radius:16px;
  background:#0b2345;
  color:#fff;
}
.line-callout a{
  font-size:26px;
  font-weight:900;
}
@media (max-width:1024px){
  .price-detail-wrap,
  .line-layout{
    grid-template-columns:1fr;
  }
}
@media (max-width:768px){
  .recruit-hero,
  .recruit-hero-inner{
    height:300px !important;
    min-height:300px !important;
  }
  .recruit-hero h1{
    font-size:30px !important;
  }
  .price-card-link{
    display:block;
  }
  .price-gallery-main{
    height:260px;
  }
  .price-detail-card{
    padding:22px 18px;
  }
  .price-detail-value strong{
    font-size:44px;
  }
  .line-guide,
  .price-detail-notes .card{
    padding:22px 18px;
  }
}

/* ===== actual final swap home price/title and animate flow halos ===== */
.price-tile > div{
  display:flex !important;
  flex-direction:column !important;
  align-items:flex-start !important;
}
.price-tile h3{
  order:2 !important;
  margin:8px 0 0 !important;
}
.price-tile .price{
  order:1 !important;
  margin-top:0 !important;
}
.home-flow-visual .step::before{
  z-index:2 !important;
  animation:homeFlowDotPulseFinal 1.8s ease-in-out infinite !important;
}
.home-flow-visual .step::after{
  content:"" !important;
  position:absolute !important;
  left:50% !important;
  top:0 !important;
  width:48px !important;
  height:48px !important;
  border-radius:999px !important;
  transform:translateX(-50%) !important;
  background:rgba(217,47,47,.25) !important;
  box-shadow:0 0 0 0 rgba(217,47,47,.34) !important;
  animation:homeFlowHaloPulseFinal 1.8s ease-out infinite !important;
  z-index:1 !important;
}
@keyframes homeFlowDotPulseFinal{
  0%,100%{box-shadow:0 0 0 8px rgba(217,47,47,.16),0 12px 28px rgba(0,0,0,.28)}
  50%{box-shadow:0 0 0 13px rgba(217,47,47,.24),0 16px 34px rgba(0,0,0,.34)}
}
@keyframes homeFlowHaloPulseFinal{
  0%{opacity:.78; transform:translateX(-50%) scale(1)}
  70%{opacity:0; transform:translateX(-50%) scale(1.85)}
  100%{opacity:0; transform:translateX(-50%) scale(1.85)}
}
@media (max-width:1024px){
  .home-flow-visual .step::after{
    left:20px !important;
    top:20px !important;
    transform:none !important;
  }
  @keyframes homeFlowHaloPulseFinal{
    0%{opacity:.78; transform:scale(1)}
    70%{opacity:0; transform:scale(1.85)}
    100%{opacity:0; transform:scale(1.85)}
  }
}

/* ===== final swap home price/title and animate flow halos ===== */
.price-tile > div{
  display:flex !important;
  flex-direction:column !important;
  align-items:flex-start !important;
}
.price-tile h3{
  order:2 !important;
  margin:8px 0 0 !important;
}
.price-tile .price{
  order:1 !important;
  margin-top:0 !important;
}
.home-flow-visual .step::before{
  z-index:2 !important;
  animation:homeFlowDotPulse 1.8s ease-in-out infinite !important;
}
.home-flow-visual .step::after{
  content:"" !important;
  position:absolute !important;
  left:50% !important;
  top:0 !important;
  width:48px !important;
  height:48px !important;
  border-radius:999px !important;
  transform:translateX(-50%) !important;
  background:rgba(217,47,47,.25) !important;
  box-shadow:0 0 0 0 rgba(217,47,47,.34) !important;
  animation:homeFlowHaloPulse 1.8s ease-out infinite !important;
  z-index:1 !important;
}
@keyframes homeFlowDotPulse{
  0%,100%{box-shadow:0 0 0 8px rgba(217,47,47,.16),0 12px 28px rgba(0,0,0,.28)}
  50%{box-shadow:0 0 0 13px rgba(217,47,47,.24),0 16px 34px rgba(0,0,0,.34)}
}
@keyframes homeFlowHaloPulse{
  0%{opacity:.78; transform:translateX(-50%) scale(1)}
  70%{opacity:0; transform:translateX(-50%) scale(1.85)}
  100%{opacity:0; transform:translateX(-50%) scale(1.85)}
}
@media (max-width:1024px){
  .home-flow-visual .step::after{
    left:20px !important;
    top:20px !important;
    transform:none !important;
  }
  @keyframes homeFlowHaloPulse{
    0%{opacity:.78; transform:scale(1)}
    70%{opacity:0; transform:scale(1.85)}
    100%{opacity:0; transform:scale(1.85)}
  }
}

/* ===== actual final homepage layout polish after badge rules ===== */
.section:has(.price-preview){
  padding-top:52px !important;
  padding-bottom:52px !important;
  background:#fff !important;
}
.section:has(.price-preview) .section-title{
  font-size:48px !important;
}
.section:has(.price-preview) .price-preview{
  gap:18px !important;
}
.section:has(.price-preview) .price-tile{
  min-height:164px !important;
  padding:22px !important;
}
.section:has(.price-preview) .price-tile h3{
  font-size:22px !important;
}
.section:has(.price-preview) .price-tile .price{
  font-size:26px !important;
}
.section.alt:has(.special-carousel){
  padding-top:74px !important;
  padding-bottom:74px !important;
}
.banner.banner-full.special-carousel{
  margin-bottom:0 !important;
}
@media (max-width:768px){
  .section:has(.price-preview){
    padding-top:44px !important;
    padding-bottom:44px !important;
  }
  .section:has(.price-preview) .section-title{
    font-size:38px !important;
  }
  .section.alt:has(.special-carousel){
    padding-top:48px !important;
    padding-bottom:52px !important;
  }
}

/* ===== final homepage section layout polish ===== */
.section:has(.price-preview){
  padding-top:52px !important;
  padding-bottom:52px !important;
  background:#fff !important;
}
.section:has(.price-preview) .section-title{
  font-size:48px !important;
}
.section:has(.price-preview) .price-preview{
  gap:18px !important;
}
.section:has(.price-preview) .price-tile{
  min-height:164px !important;
  padding:22px !important;
}
.section:has(.price-preview) .price-tile h3{
  font-size:22px !important;
}
.section:has(.price-preview) .price-tile .price{
  font-size:26px !important;
}
.section.alt:has(.special-carousel){
  padding-top:74px !important;
  padding-bottom:74px !important;
}
.banner.banner-full.special-carousel{
  margin-bottom:0 !important;
}
.section.alt:has(.special-carousel) + .section{
  padding-top:72px !important;
}
.home-flow-visual{
  position:relative !important;
  overflow:hidden !important;
  background:
    linear-gradient(90deg,rgba(8,16,29,.92),rgba(8,16,29,.74)),
    url('../images/page-flow.jpg') center/cover no-repeat !important;
  color:#fff !important;
}
.home-flow-visual .container{
  position:relative;
  z-index:1;
}
.home-flow-visual .section-kicker,
.home-flow-visual .section-title,
.home-flow-visual .section-head,
.home-flow-visual .section-head .btn{
  color:#fff !important;
}
.home-flow-visual .section-head .btn{
  border-color:rgba(255,255,255,.55) !important;
  background:rgba(255,255,255,.08) !important;
}
.home-flow-visual .steps{
  position:relative;
  grid-template-columns:repeat(5,minmax(0,1fr)) !important;
  gap:0 !important;
  padding:26px 0 0 !important;
}
.home-flow-visual .steps::before{
  content:"";
  position:absolute;
  left:8%;
  right:8%;
  top:49px;
  height:2px;
  background:linear-gradient(90deg,rgba(255,255,255,.16),rgba(255,255,255,.58),rgba(255,255,255,.16));
}
.home-flow-visual .step{
  min-height:0 !important;
  padding:76px 18px 0 !important;
  border:0 !important;
  border-radius:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  text-align:center;
}
.home-flow-visual .step::before{
  left:50% !important;
  top:0 !important;
  width:48px !important;
  height:48px !important;
  transform:translateX(-50%) !important;
  background:#d92f2f !important;
  box-shadow:0 0 0 8px rgba(217,47,47,.16), 0 12px 28px rgba(0,0,0,.28) !important;
}
.home-flow-visual .step h3{
  margin:0 0 10px !important;
  color:#fff !important;
}
.home-flow-visual .step p{
  color:rgba(255,255,255,.78) !important;
}
@media (max-width:1024px){
  .home-flow-visual .steps{
    grid-template-columns:1fr !important;
    gap:16px !important;
    padding-top:0 !important;
  }
  .home-flow-visual .steps::before{
    display:none;
  }
  .home-flow-visual .step{
    display:grid;
    grid-template-columns:60px minmax(0,1fr);
    text-align:left;
    padding:20px !important;
    border:1px solid rgba(255,255,255,.18) !important;
    border-radius:16px !important;
    background:rgba(255,255,255,.08) !important;
  }
  .home-flow-visual .step::before{
    position:static !important;
    transform:none !important;
    grid-row:1 / span 2;
  }
}
@media (max-width:768px){
  .section:has(.price-preview){
    padding-top:44px !important;
    padding-bottom:44px !important;
  }
  .section:has(.price-preview) .section-title{
    font-size:38px !important;
  }
  .section.alt:has(.special-carousel){
    padding-top:48px !important;
    padding-bottom:52px !important;
  }
}

/* ===== final home price card polish ===== */
.price-tile{
  grid-template-columns:104px minmax(0,1fr) !important;
}
.price-tile img{
  width:104px !important;
  height:104px !important;
}
.price-tile .badge{
  padding-top:18px !important;
}
.price-tile .price.textual.trend-flat,
.price-tile .price.textual{
  font-size:32px !important;
  line-height:1.15 !important;
}
@media (max-width:768px){
  .price-tile{
    grid-template-columns:108px minmax(0,1fr) !important;
    gap:18px !important;
  }
  .price-tile img{
    width:108px !important;
    height:108px !important;
  }
  .price-tile .price.textual.trend-flat,
  .price-tile .price.textual{
    font-size:30px !important;
  }
}
@media (max-width:420px){
  .price-tile{
    grid-template-columns:96px minmax(0,1fr) !important;
  }
  .price-tile img{
    width:96px !important;
    height:96px !important;
  }
  .price-tile .badge{
    padding-top:17px !important;
  }
  .price-tile .price.textual.trend-flat,
  .price-tile .price.textual{
    font-size:27px !important;
  }
}

/* ===== compact home price badge fix ===== */
.price-tile .badge{
  left:7px !important;
  top:2px !important;
  width:58px !important;
  min-width:58px !important;
  height:58px !important;
  padding:12px 0 0 !important;
  font-size:13px !important;
  line-height:1 !important;
  z-index:6 !important;
}
.price-tile .badge::before{
  top:6px !important;
  width:48px !important;
  height:48px !important;
}
.price-tile .badge::after{
  top:11px !important;
  width:38px !important;
  height:38px !important;
}
@media (max-width:420px){
  .price-tile .badge{
    left:8px !important;
    top:5px !important;
    width:56px !important;
    min-width:56px !important;
    height:56px !important;
    padding-top:12px !important;
    font-size:12px !important;
  }
  .price-tile .badge::before{
    top:6px !important;
    width:46px !important;
    height:46px !important;
  }
  .price-tile .badge::after{
    top:11px !important;
    width:36px !important;
    height:36px !important;
  }
}

/* ===== special purchase responsive carousel ===== */
.banner.banner-full.special-carousel{
  position:relative !important;
  display:block !important;
  aspect-ratio:2048 / 697 !important;
  margin:0 0 48px !important;
  overflow:hidden !important;
  border-radius:26px !important;
  background:#090909 !important;
  box-shadow:0 10px 30px rgba(16,35,69,.12) !important;
}
.special-carousel-track,
.special-carousel-slide,
.special-carousel-slide picture{
  position:absolute !important;
  inset:0 !important;
  display:block !important;
  width:100% !important;
  height:100% !important;
}
.special-carousel-slide{
  opacity:0;
  pointer-events:none;
  transition:opacity .55s ease;
}
.special-carousel-slide.active{
  opacity:1;
  pointer-events:auto;
}
.banner-full.special-carousel img{
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  max-width:none !important;
  object-fit:cover !important;
  border-radius:0 !important;
  box-shadow:none !important;
}
.special-carousel-btn{
  position:absolute;
  top:50%;
  z-index:3;
  width:42px;
  height:42px;
  border:1px solid rgba(255,255,255,.45);
  border-radius:999px;
  background:rgba(0,0,0,.34);
  color:#fff;
  font-size:32px;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
  transform:translateY(-50%);
  cursor:pointer;
}
.special-carousel-btn.prev{left:14px}
.special-carousel-btn.next{right:14px}
.special-carousel-dots{
  position:absolute;
  left:50%;
  bottom:14px;
  z-index:3;
  display:flex;
  gap:8px;
  transform:translateX(-50%);
}
.special-carousel-dots button{
  width:10px;
  height:10px;
  padding:0;
  border:1px solid rgba(255,255,255,.8);
  border-radius:999px;
  background:rgba(255,255,255,.38);
  cursor:pointer;
}
.special-carousel-dots button.active{
  width:28px;
  background:#d9a849;
  border-color:#f1d086;
}
@media (max-width:768px){
  .banner.banner-full.special-carousel{
    aspect-ratio:1152 / 1536 !important;
    margin-bottom:36px !important;
    border-radius:20px !important;
  }
  .special-carousel-btn{
    width:36px;
    height:36px;
    font-size:28px;
  }
  .special-carousel-btn.prev{left:10px}
  .special-carousel-btn.next{right:10px}
  .special-carousel-dots{bottom:12px}
}
@media (max-width:420px){
  .price-list .card .badge,
  .price-tile .badge,
  .badge{
    left:8px !important;
    top:8px !important;
    width:74px !important;
    min-width:74px !important;
    height:66px !important;
    padding-top:3px !important;
    font-size:15px !important;
  }
  .price-list .card .badge::before,
  .price-tile .badge::before,
  .badge::before{
    top:12px !important;
    width:52px !important;
    height:52px !important;
  }
  .price-list .card .badge::after,
  .price-tile .badge::after,
  .badge::after{
    top:18px !important;
    width:40px !important;
    height:40px !important;
  }
}

/* ===== final badge label alignment fix ===== */
.price-list .card,
.price-tile{
  overflow:visible !important;
}
.price-list .card .badge,
.price-tile .badge,
.badge{
  width:92px !important;
  min-width:92px !important;
  height:86px !important;
  padding:24px 0 0 !important;
  box-sizing:border-box !important;
  display:block !important;
  overflow:visible !important;
  font-size:17px !important;
  line-height:1 !important;
  text-align:center !important;
}
.price-list .card .badge::before,
.price-tile .badge::before,
.badge::before{
  top:10px !important;
  width:68px !important;
  height:68px !important;
}
.price-list .card .badge::after,
.price-tile .badge::after,
.badge::after{
  top:17px !important;
  width:54px !important;
  height:54px !important;
}
@media (max-width:768px){
  .price-list .card .badge,
  .price-tile .badge,
  .badge{
    width:84px !important;
    min-width:84px !important;
    height:78px !important;
    padding-top:22px !important;
    font-size:16px !important;
  }
  .price-list .card .badge::before,
  .price-tile .badge::before,
  .badge::before{
    top:9px !important;
    width:62px !important;
    height:62px !important;
  }
  .price-list .card .badge::after,
  .price-tile .badge::after,
  .badge::after{
    top:16px !important;
    width:48px !important;
    height:48px !important;
  }
}
@media (max-width:420px){
  .price-list .card .badge,
  .price-tile .badge,
  .badge{
    width:76px !important;
    min-width:76px !important;
    height:70px !important;
    padding-top:20px !important;
    font-size:15px !important;
  }
  .price-list .card .badge::before,
  .price-tile .badge::before,
  .badge::before{
    top:8px !important;
    width:56px !important;
    height:56px !important;
  }
  .price-list .card .badge::after,
  .price-tile .badge::after,
  .badge::after{
    top:14px !important;
    width:44px !important;
    height:44px !important;
  }
}

/* ===== actual final compact home price badge fix ===== */
.price-tile .badge{
  left:7px !important;
  top:2px !important;
  width:58px !important;
  min-width:58px !important;
  height:58px !important;
  padding:12px 0 0 !important;
  font-size:13px !important;
  line-height:1 !important;
  z-index:6 !important;
}
.price-tile .badge::before{
  top:6px !important;
  width:48px !important;
  height:48px !important;
}
.price-tile .badge::after{
  top:11px !important;
  width:38px !important;
  height:38px !important;
}
@media (max-width:420px){
  .price-tile .badge{
    left:8px !important;
    top:5px !important;
    width:56px !important;
    min-width:56px !important;
    height:56px !important;
    padding-top:12px !important;
    font-size:12px !important;
  }
  .price-tile .badge::before{
    top:6px !important;
    width:46px !important;
    height:46px !important;
  }
  .price-tile .badge::after{
    top:11px !important;
    width:36px !important;
    height:36px !important;
  }
}

/* ===== actual final carousel arrow vertical center fix ===== */
.banner.banner-full.special-carousel > .special-carousel-btn{
  top:50% !important;
  bottom:auto !important;
  margin:0 !important;
  padding:0 0 10px !important;
  transform:translateY(-50%) !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  line-height:1 !important;
}
.banner.banner-full.special-carousel > .special-carousel-btn.prev{
  left:14px !important;
}
.banner.banner-full.special-carousel > .special-carousel-btn.next{
  right:14px !important;
}
@media (max-width:768px){
  .banner.banner-full.special-carousel > .special-carousel-btn.prev{
    left:10px !important;
  }
  .banner.banner-full.special-carousel > .special-carousel-btn.next{
    right:10px !important;
  }
}

/* ===== actual final home price card polish after all overrides ===== */
.price-tile{
  grid-template-columns:104px minmax(0,1fr) !important;
}
.price-tile img{
  width:104px !important;
  height:104px !important;
}
.price-tile .badge{
  padding-top:18px !important;
}
.price-tile .price.textual.trend-flat,
.price-tile .price.textual{
  font-size:32px !important;
  line-height:1.15 !important;
}
@media (max-width:768px){
  .price-tile{
    grid-template-columns:108px minmax(0,1fr) !important;
    gap:18px !important;
  }
  .price-tile img{
    width:108px !important;
    height:108px !important;
  }
  .price-tile .price.textual.trend-flat,
  .price-tile .price.textual{
    font-size:30px !important;
  }
}
@media (max-width:420px){
  .price-tile{
    grid-template-columns:96px minmax(0,1fr) !important;
  }
  .price-tile img{
    width:96px !important;
    height:96px !important;
  }
  .price-tile .badge{
    padding-top:17px !important;
  }
  .price-tile .price.textual.trend-flat,
  .price-tile .price.textual{
    font-size:27px !important;
  }
}

/* ===== actual final separate up badge tuning: home tiles ===== */
.price-tile .badge.up{
  left:8px !important;
  top:4px !important;
  width:58px !important;
  min-width:58px !important;
  height:58px !important;
  padding-top:25px !important;
  font-size:13px !important;
  line-height:1 !important;
}
.price-tile .badge.up::before{
  top:6px !important;
  width:48px !important;
  height:48px !important;
}
.price-tile .badge.up::after{
  top:11px !important;
  width:38px !important;
  height:38px !important;
}

/* ===== actual final separate up badge tuning: price list cards ===== */
.price-list .card .badge.up{
  left:12px !important;
  top:12px !important;
  width:90px !important;
  min-width:90px !important;
  height:90px !important;
  padding-top:45px !important;
  font-size:17px !important;
  line-height:1 !important;
}
.price-list .card .badge.up::before{
  top:7px !important;
  width:80px !important;
  height:80px !important;
}
.price-list .card .badge.up::after{
  top:13px !important;
  width:44px !important;
  height:44px !important;
}
@media (max-width:768px){
  .price-list .card .badge.up{
    left:12px !important;
    top:12px !important;
    width:84px !important;
    min-width:84px !important;
    height:84px !important;
    padding-top:39px !important;
    font-size:16px !important;
  }
  .price-list .card .badge.up::before{
    top:7px !important;
    width:70px !important;
    height:70px !important;
  }
  .price-list .card .badge.up::after{
    top:12px !important;
    width:40px !important;
    height:40px !important;
  }
}
/* ===== eof final swap home price/title and animate flow halos ===== */
.price-tile > div{
  display:flex !important;
  flex-direction:column !important;
  align-items:flex-start !important;
}
.price-tile h3{
  order:2 !important;
  margin:8px 0 0 !important;
}
.price-tile .price{
  order:1 !important;
  margin-top:0 !important;
}
.home-flow-visual .step::before{
  z-index:2 !important;
  animation:homeFlowDotPulseEof 1.8s ease-in-out infinite !important;
}
.home-flow-visual .step::after{
  content:"" !important;
  position:absolute !important;
  left:50% !important;
  top:0 !important;
  width:48px !important;
  height:48px !important;
  border-radius:999px !important;
  transform:translateX(-50%) !important;
  background:rgba(217,47,47,.25) !important;
  animation:homeFlowHaloPulseEof 1.8s ease-out infinite !important;
  z-index:1 !important;
}
@keyframes homeFlowDotPulseEof{
  0%,100%{box-shadow:0 0 0 8px rgba(217,47,47,.16),0 12px 28px rgba(0,0,0,.28)}
  50%{box-shadow:0 0 0 13px rgba(217,47,47,.24),0 16px 34px rgba(0,0,0,.34)}
}
@keyframes homeFlowHaloPulseEof{
  0%{opacity:.78; transform:translateX(-50%) scale(1)}
  70%{opacity:0; transform:translateX(-50%) scale(1.85)}
  100%{opacity:0; transform:translateX(-50%) scale(1.85)}
}
@media (max-width:1024px){
  .home-flow-visual .step::after{
    left:20px !important;
    top:20px !important;
    transform:none !important;
  }
  @keyframes homeFlowHaloPulseEof{
    0%{opacity:.78; transform:scale(1)}
    70%{opacity:0; transform:scale(1.85)}
    100%{opacity:0; transform:scale(1.85)}
  }
}

/* ===== 20260628 home animation and contact LINE card ===== */
@keyframes homeSoftIn{0%{opacity:0;transform:translateY(18px)}100%{opacity:1;transform:translateY(0)}}
@keyframes homeImageBreath{0%,100%{transform:scale(1)}50%{transform:scale(1.025)}}
body .hero-cover-copy,
body .price-preview .price-tile,
body #purchase-items .category-card,
body .home-news-card,
body .reason-card,
body .home-flow-visual .step{opacity:0;animation:homeSoftIn .68s ease forwards}
body .hero-cover-copy{animation-delay:.05s}
body .price-preview .price-tile:nth-child(1),body #purchase-items .category-card:nth-child(1){animation-delay:.08s}
body .price-preview .price-tile:nth-child(2),body #purchase-items .category-card:nth-child(2){animation-delay:.16s}
body .price-preview .price-tile:nth-child(3),body #purchase-items .category-card:nth-child(3){animation-delay:.24s}
body .price-preview .price-tile:nth-child(4),body #purchase-items .category-card:nth-child(4){animation-delay:.32s}
body .price-preview .price-tile:nth-child(5),body #purchase-items .category-card:nth-child(5){animation-delay:.40s}
body .price-preview .price-tile:nth-child(6),body #purchase-items .category-card:nth-child(6){animation-delay:.48s}
body .hero-cover::before{animation:homeImageBreath 10s ease-in-out infinite}
.contact-line-card{display:grid;gap:8px;margin-top:12px;padding:22px;min-height:210px;border-radius:18px;background:linear-gradient(180deg,#06c755,#00a946);color:#fff!important;box-shadow:0 14px 28px rgba(0,166,70,.22);position:relative;overflow:hidden}
.contact-line-card::after{content:"";position:absolute;right:-34px;bottom:-42px;width:130px;height:130px;border-radius:50%;background:rgba(255,255,255,.16)}
.contact-line-card strong{font-size:24px;line-height:1.25;position:relative;z-index:1}.contact-line-card em{font-style:normal;font-size:18px;font-weight:900;line-height:1.45;position:relative;z-index:1}.contact-line-card small{font-size:14px;color:rgba(255,255,255,.88);position:relative;z-index:1}
.line-live{display:inline-flex;align-items:center;gap:6px;width:max-content;padding:5px 10px;border-radius:999px;background:rgba(255,255,255,.2);font-weight:900;font-size:12px;letter-spacing:.08em;position:relative;z-index:1}
.line-live::before{content:"";width:8px;height:8px;border-radius:50%;background:#fff;box-shadow:0 0 0 0 rgba(255,255,255,.7);animation:linePulse 1.4s ease-out infinite}
@keyframes linePulse{0%{box-shadow:0 0 0 0 rgba(255,255,255,.7)}70%{box-shadow:0 0 0 10px rgba(255,255,255,0)}100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}
@media (max-width:768px){.contact-line-card{min-height:160px;padding:20px}.contact-line-card strong{font-size:22px}.contact-line-card em{font-size:16px}}

/* ===== contact LINE card color fix ===== */
.contact-line-card{background:rgb(98, 200, 89)!important;color:#fff!important}
.contact-line-card strong,.contact-line-card em,.contact-line-card small,.contact-line-card .line-live{color:#fff!important}

/* ===== contact LINE card color fix ===== */
.contact-line-card{background:rgb(98, 200, 89)!important;color:#fff!important}
.contact-line-card strong,.contact-line-card em,.contact-line-card small,.contact-line-card .line-live{color:#fff!important}

@media (max-width:768px){
  body #purchase-items .grid-4{
    display:grid!important;
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:12px!important;
  }
  body #purchase-items .category-card{
    min-width:0!important;
    border-radius:12px!important;
  }
  body #purchase-items .category-card img{
    height:120px!important;
    border-radius:12px 12px 0 0!important;
  }
  body #purchase-items .category-card .body{
    padding:12px!important;
  }
  body #purchase-items .category-card h3{
    font-size:22px!important;
    line-height:1.25!important;
  }
  body #purchase-items .category-card p{
    font-size:13px!important;
    line-height:1.6!important;
  }
}

/* ===== price detail trend badge and color ===== */
.price-gallery{position:relative;overflow:hidden}
.price-gallery.has-price-trend-up::before{content:"";position:absolute;left:0;top:0;width:100%;height:clamp(220px,42vw,420px);background:linear-gradient(135deg,rgba(0,0,0,.52) 0%,rgba(0,0,0,.28) 24%,rgba(0,0,0,.1) 42%,rgba(0,0,0,0) 58%);pointer-events:none;z-index:2}
.price-gallery .price-trend-corner{position:absolute;left:10px;top:10px;z-index:4;width:auto;height:auto;display:flex;align-items:center;justify-content:center;background:transparent!important;border-radius:0!important;box-shadow:none!important;filter:none!important;animation:priceCornerFloat 1.2s ease-in-out infinite!important}
.price-gallery .price-trend-corner .price-arrow-up{width:36px!important;height:40px!important;margin:0!important;display:block!important;background:linear-gradient(180deg,#ff3b55 0%,#ff2f2f 58%,#ef5b00 100%)!important;clip-path:polygon(50% 0,100% 45%,70% 45%,70% 100%,30% 100%,30% 45%,0 45%)!important;filter:drop-shadow(0 1px 1px rgba(0,0,0,.95)) drop-shadow(0 3px 6px rgba(0,0,0,.75)) drop-shadow(0 8px 14px rgba(0,0,0,.45))!important;animation:priceArrowUpBounce 1s ease-in-out infinite!important}
.price-detail-value .price-up-mark{display:inline-block!important;margin-left:8px!important;font-size:26px!important;line-height:1!important;font-weight:900!important;color:#d92f2f!important;animation:priceUpMarkPulse 1.1s ease-in-out infinite!important;vertical-align:2px!important}
.price-gallery .badge{left:8px!important;top:8px!important;z-index:3}
.price-detail-value.trend-up,.price-detail-value.trend-up *{color:#d92f2f!important}
.price-detail-value.trend-down,.price-detail-value.trend-down *{color:#1b8f46!important}
.price-detail-value.trend-flat,.price-detail-value.trend-flat *{color:#111827!important}
.price-detail-value .price-arrow{font-size:.56em;margin-left:8px;vertical-align:middle}

/* ===== remove trend badge solid background ===== */
.badge,.price-tile .badge,.price-list .card .badge,.price-gallery .badge{background:transparent!important;box-shadow:none!important}
.badge.up,.price-tile .badge.up,.price-list .card .badge.up,.price-gallery .badge.up,.badge.down,.price-tile .badge.down,.price-list .card .badge.down,.price-gallery .badge.down{background-color:transparent!important;background-image:none!important}

/* ===== contact LINE card header spacing/alignment ===== */
.contact-line-card{gap:12px!important;padding:24px!important;align-content:start!important}
.contact-line-card strong{display:flex!important;align-items:center!important;gap:10px!important;margin:0 0 2px!important;line-height:1.25!important}
.contact-line-card .line-live{align-self:center!important;margin-top:0!important;transform:translateY(0)!important}

/* ===== backend maintained home hero banner ===== */
.hero-cover{position:relative;isolation:isolate;background:#102238!important;overflow:hidden}
.hero-cover::before{display:none!important}
.hero-cover::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(8,16,29,.84) 0%,rgba(8,16,29,.76) 28%,rgba(8,16,29,.48) 48%,rgba(8,16,29,.18) 68%,rgba(8,16,29,.06) 100%)}
.hero-cover-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-cover-slide{position:absolute;inset:0;opacity:0;transition:opacity 900ms ease;display:block}
.hero-cover-slide.active{opacity:1}
.hero-cover-slide img{width:100%;height:100%;object-fit:cover;object-position:center center;display:block;transform:scale(1.01)}
.hero-cover-slide.active img{animation:homeHeroKenBurns 9s ease-in-out infinite alternate}
.hero-cover .container{position:relative;z-index:2}
@keyframes homeHeroKenBurns{0%{transform:scale(1.01) translate3d(0,0,0)}100%{transform:scale(1.06) translate3d(-1.2%,0,0)}}
@media (max-width:768px){.hero-cover::after{background:linear-gradient(180deg,rgba(8,16,29,.70) 0%,rgba(8,16,29,.54) 32%,rgba(8,16,29,.28) 58%,rgba(8,16,29,.18) 100%)}.hero-cover-slide img{object-position:64% center}}

/* ===== home mobile hero position/buttons only ===== */
@media (max-width:768px){
  body.home-index .hero-cover,
  .hero-cover{align-items:flex-start!important;min-height:320px!important}
  .hero-cover-copy{padding-top:20px!important;padding-bottom:24px!important}
  .hero-cover .hero-actions{display:none!important}
}

/* price unit and tax small */
.price .price-unit,.price .price-tax{font-size:.55em!important;font-weight:900!important;line-height:1!important;margin-left:4px!important;vertical-align:baseline!important;white-space:nowrap!important}.price .price-tax{font-size:.46em!important;margin-left:6px!important}

/* price display final: tax/unit same size, only up trend animated */
.price .price-unit,.price .price-tax{font-size:.55em!important;font-weight:900!important;line-height:1!important;margin-left:4px!important;vertical-align:baseline!important;white-space:nowrap!important}
.price.trend-down,.price.trend-down *,.price-list .card .price.trend-down,.price-list .card .price.trend-down *{color:#111827!important}
.price.trend-up,.price.trend-up *,.price-list .card .price.trend-up,.price-list .card .price.trend-up *{color:#d92f2f!important}
.price-list .card{height:100%!important;display:flex!important;flex-direction:column!important}
.price-list .card .price-card-link{height:100%!important;display:flex!important;flex-direction:column!important}
.price-list .card .body{flex:1!important;display:flex!important;flex-direction:column!important}
.price-list .card .body small{margin-top:auto!important;min-height:52px!important;display:flex!important;align-items:center!important;justify-content:space-between!important}
.price-arrow-up{display:inline-block!important;width:.78em!important;height:.9em!important;margin-left:10px!important;background:linear-gradient(180deg,#ff2f55,#e33a00)!important;clip-path:polygon(50% 0,100% 45%,70% 45%,70% 100%,30% 100%,30% 45%,0 45%)!important;animation:priceArrowUpPulse 1.1s ease-in-out infinite!important;vertical-align:-.08em!important}
@keyframes priceArrowUpPulse{0%,100%{transform:translateY(2px) scale(1);opacity:.85}50%{transform:translateY(-4px) scale(1.08);opacity:1}}
.badge.down,.badge.flat{display:none!important}
/* price final 202606302310 */
.price .price-unit,.price .price-tax{font-size:.55em!important;font-weight:900!important;line-height:1!important;margin-left:4px!important;vertical-align:baseline!important;white-space:nowrap!important}
.price.trend-down,.price.trend-down *,.price-list .card .price.trend-down,.price-list .card .price.trend-down *{color:#111827!important}
.price.trend-up,.price.trend-up *,.price-list .card .price.trend-up,.price-list .card .price.trend-up *{color:#d92f2f!important}
.price-list .card{height:100%!important;display:flex!important;flex-direction:column!important}
.price-list .card .price-card-link{height:100%!important;display:flex!important;flex-direction:column!important}
.price-list .card .body{flex:1!important;display:flex!important;flex-direction:column!important}
.price-list .card .body small{margin-top:auto!important;min-height:52px!important;display:flex!important;align-items:center!important;justify-content:space-between!important}
.price-arrow-up{display:inline-block!important;width:.78em!important;height:.9em!important;margin-left:10px!important;background:linear-gradient(180deg,#ff2f55,#e33a00)!important;clip-path:polygon(50% 0,100% 45%,70% 45%,70% 100%,30% 100%,30% 45%,0 45%)!important;animation:priceArrowUpPulse 1.1s ease-in-out infinite!important;vertical-align:-.08em!important}
@keyframes priceArrowUpPulse{0%,100%{transform:translateY(2px) scale(1);opacity:.85}50%{transform:translateY(-4px) scale(1.08);opacity:1}}
.badge.down,.badge.flat{display:none!important}
/* price card final alignment 202606302330 */
.price-list .card .price{display:flex!important;align-items:baseline!important;gap:4px!important;flex-wrap:nowrap!important;white-space:nowrap!important;line-height:1.1!important}
.price-list .card .price .price-value{font-size:1em!important;font-weight:900!important}
.price-list .card .price .price-unit,.price-list .card .price .price-tax{font-size:.55em!important;font-weight:900!important;line-height:1!important;margin-left:2px!important;white-space:nowrap!important;vertical-align:baseline!important}
.price-list .card .price .price-tax{margin-left:8px!important}
.price-list .card .body small{width:100%!important;min-height:34px!important;margin-top:auto!important;padding-top:12px!important;display:flex!important;align-items:center!important;justify-content:space-between!important;gap:10px!important;font-size:13px!important;line-height:1.2!important;white-space:nowrap!important}
.price-list .card .body small span{white-space:nowrap!important;word-break:keep-all!important;writing-mode:horizontal-tb!important}
.price-list .card .body small .consult{margin-left:auto!important;flex:0 0 auto!important;font-size:13px!important}
.price-list .card .body small span:first-child{flex:0 0 auto!important;color:#9aa0aa!important}
.price-arrow-up{flex:0 0 auto!important;width:.7em!important;height:.78em!important;margin-left:8px!important;transform:none!important}
/* price row align 202606302355 */
.price-list .card .price-card-link{display:flex!important;flex-direction:column!important;height:100%!important}
.price-list .card .body{display:grid!important;grid-template-rows:32px 44px 48px 1fr 34px!important;row-gap:8px!important;flex:1!important;min-height:190px!important}
.price-list .card .body h3{height:32px!important;line-height:32px!important;margin:0!important;overflow:hidden!important;white-space:nowrap!important;text-overflow:ellipsis!important}
.price-list .card .body p{height:44px!important;min-height:44px!important;line-height:22px!important;margin:0!important;overflow:hidden!important;display:-webkit-box!important;-webkit-line-clamp:2!important;-webkit-box-orient:vertical!important}
.price-list .card .body .price{height:48px!important;margin:0!important;display:flex!important;align-items:center!important;gap:4px!important;white-space:nowrap!important;line-height:1!important}
.price-list .card .body .price .price-value{font-size:1em!important;line-height:1!important}
.price-list .card .body .price .price-unit,.price-list .card .body .price .price-tax{font-size:.55em!important;line-height:1!important;margin-left:4px!important;align-self:center!important}
.price-list .card .body small{height:34px!important;min-height:34px!important;margin:0!important;padding-top:10px!important;display:flex!important;align-items:center!important;justify-content:space-between!important;gap:10px!important;white-space:nowrap!important;border-top:1px solid #e7ebf0!important}
.price-list .card .body small span{writing-mode:horizontal-tb!important;white-space:nowrap!important;word-break:keep-all!important}
@media (max-width:768px){.price-list .card .body{grid-template-rows:auto 40px 42px 1fr 34px!important;min-height:176px!important}.price-list .card .body h3{height:auto!important;line-height:1.35!important;white-space:normal!important}.price-list .card .body p{height:40px!important;min-height:40px!important;line-height:20px!important}.price-list .card .body .price{height:42px!important}}
/* server fallback price cards 202607010005 */
.price-list .card{opacity:1!important;visibility:visible!important;transform:none!important}
.price-list .card .price-fallback-text{font-size:1em!important;font-weight:900!important;white-space:nowrap!important}
.price-list .card .price-fallback-text{font-feature-settings:"palt"}
/* force prices visible 202607010020 */
.hero-prices + .section.alt{display:block!important;visibility:visible!important;opacity:1!important;transform:none!important;min-height:auto!important;padding:72px 0!important;background:#f6f8fb!important}
.hero-prices + .section.alt > .container.layout{display:grid!important;grid-template-columns:280px minmax(0,1fr)!important;gap:28px!important;align-items:start!important;visibility:visible!important;opacity:1!important;transform:none!important}
.hero-prices + .section.alt .side,.hero-prices + .section.alt main,.hero-prices + .section.alt .searchbar,.hero-prices + .section.alt .note,.hero-prices + .section.alt .price-list{display:grid!important;visibility:visible!important;opacity:1!important;transform:none!important}
.hero-prices + .section.alt .searchbar{display:flex!important}
.hero-prices + .section.alt .price-list{grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:22px!important;min-height:200px!important}
.hero-prices + .section.alt .price-list .card{display:flex!important;visibility:visible!important;opacity:1!important;transform:none!important;position:relative!important;background:#fff!important}
.hero-prices + .section.alt .price-list .card .price-card-link{display:flex!important;visibility:visible!important;opacity:1!important;transform:none!important;color:inherit!important;text-decoration:none!important}
@media (max-width:1024px){.hero-prices + .section.alt > .container.layout{grid-template-columns:1fr!important}.hero-prices + .section.alt .price-list{grid-template-columns:repeat(2,minmax(0,1fr))!important}}
@media (max-width:768px){.hero-prices + .section.alt{padding:48px 0 72px!important}.hero-prices + .section.alt .price-list{grid-template-columns:1fr!important}.hero-prices + .section.alt .searchbar{display:grid!important;grid-template-columns:1fr!important}}
/* price up corner arrow 202607010130 */
.price-list .card,.price-list .card .price-card-link{position:relative!important;overflow:hidden!important}
.price-trend-corner{position:absolute!important;left:10px!important;top:10px!important;z-index:3!important;width:42px!important;height:42px!important;border-radius:999px!important;background:rgba(255,255,255,.92)!important;box-shadow:0 8px 18px rgba(217,47,47,.22)!important;display:flex!important;align-items:center!important;justify-content:center!important}
.price-trend-corner .price-arrow-up{width:24px!important;height:28px!important;margin:0!important;display:block!important}
.price-list .card .price > .price-arrow-up:not(.price-arrow-inline){display:none!important}

/* home purchase item mobile layout fix 202607010210 */
@media (max-width:768px){
  body #purchase-items .grid-4{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:14px!important;align-items:stretch!important;width:100%!important}
  body #purchase-items .category-card{width:auto!important;min-width:0!important;max-width:none!important;display:flex!important;flex-direction:column!important;border-radius:10px!important;overflow:hidden!important}
  body #purchase-items .category-card img{width:100%!important;height:118px!important;aspect-ratio:auto!important;object-fit:cover!important;display:block!important;border-radius:0!important}
  body #purchase-items .category-card .body{padding:12px 12px 14px!important;display:flex!important;flex-direction:column!important;min-height:112px!important}
  body #purchase-items .category-card h3{font-size:20px!important;line-height:1.25!important;margin:0 0 8px!important;word-break:keep-all!important;overflow-wrap:anywhere!important;letter-spacing:0!important}
  body #purchase-items .category-card p{font-size:12px!important;line-height:1.55!important;margin:0!important;color:#6b7280!important;display:-webkit-box!important;-webkit-line-clamp:2!important;-webkit-box-orient:vertical!important;overflow:hidden!important}
}

/* price page sidebar and up arrow final 202607010245 */
.price-side .side-tools{display:none!important}
.price-trend-corner{background:transparent!important;box-shadow:none!important;border-radius:0!important;width:auto!important;height:auto!important;left:8px!important;top:8px!important;overflow:visible!important;animation:priceCornerFloat 1.2s ease-in-out infinite!important}
.price-trend-corner .price-arrow-up{width:36px!important;height:40px!important;background:linear-gradient(180deg,#ff3b55 0%,#ff2f2f 58%,#ef5b00 100%)!important;filter:drop-shadow(0 1px 1px rgba(0,0,0,.95)) drop-shadow(0 3px 6px rgba(0,0,0,.75)) drop-shadow(0 8px 14px rgba(0,0,0,.45))!important;animation:priceArrowUpBounce 1s ease-in-out infinite!important}
@keyframes priceCornerFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
@keyframes priceArrowUpBounce{0%,100%{transform:translateY(3px) scale(1)}50%{transform:translateY(-4px) scale(1.12)}}

/* price inline up arrow 202607010305 */
.price-list .card .price .price-arrow-inline{display:inline-block!important;position:static!important;width:24px!important;height:28px!important;margin-left:8px!important;vertical-align:-5px!important;background:linear-gradient(180deg,#ff3b55 0%,#ff2f2f 58%,#ef5b00 100%)!important;filter:drop-shadow(0 3px 4px rgba(210,0,0,.3))!important;animation:priceArrowUpBounce 1s ease-in-out infinite!important;flex:0 0 auto!important}
.price-list .card .price{overflow:visible!important}

/* price small up mark 202607010320 */
.price-list .card .price .price-arrow-inline{display:none!important}
.price-list .card .price .price-up-mark{display:inline-block!important;margin-left:8px!important;font-size:26px!important;line-height:1!important;font-weight:900!important;color:#d92f2f!important;animation:priceUpMarkPulse 1.1s ease-in-out infinite!important;vertical-align:2px!important}
@keyframes priceUpMarkPulse{0%,100%{transform:translate(0,0);opacity:.82}50%{transform:translate(2px,-2px);opacity:1}}

/* price page remove mobile toggle and note 202607010350 */
.price-filter-toggle,.hero-prices + .section.alt .note{display:none!important}

/* header requested styles 202607010410 */
.header-inner{display:flex!important;align-items:center!important;gap:18px!important;min-height:88px!important}
.nav a{padding:12px 7px!important;font-weight:700!important;font-size:16px!important;color:#1f2937!important;border-bottom:3px solid transparent!important;transition:.2s!important;white-space:nowrap!important;word-break:keep-all!important}
.header .brand-title{font-size:18px!important;font-weight:800!important;letter-spacing:.02em!important;color:#111827!important;white-space:nowrap!important}
@media (max-width:1024px){.header-inner{min-height:78px!important}.header .brand-title{font-size:16px!important}.nav a{font-size:13px!important}}

/* nav active state restore 202607010735 */
.header .nav > a.active,
.header .nav > a[aria-current="page"]{
  color:var(--red)!important;
  border-bottom-color:var(--red)!important;
  background:#fff2f2!important;
}
.mobile-drawer-nav a.active,
.mobile-drawer-nav a[aria-current="page"]{
  color:var(--red)!important;
  background:#fff2f2!important;
}

/* header nav fit and active fix 202607010755 */
@media (min-width:1321px){
  .brand{min-width:200px!important}
  .header .brand-title{font-size:18px!important}
  .nav{gap:0!important;overflow:visible!important}
  .header .nav > a{font-size:16px!important;padding:12px 6px!important}
}

/* nav active online fix 202607011020 */
.header .nav > a.active,
.header .nav > a[aria-current="page"]{color:var(--red)!important;border-bottom-color:var(--red)!important;background:#fff2f2!important;}
.mobile-drawer-nav a.active,
.mobile-drawer-nav a[aria-current="page"]{color:var(--red)!important;background:#fff2f2!important;}
@media (min-width:1321px){.brand{min-width:200px!important}.header .brand-title{font-size:18px!important}.nav{gap:0!important;overflow:visible!important}.header .nav > a{font-size:16px!important;padding:12px 6px!important}}

/* nav menu size online fix 202607011120 */
@media (min-width:1321px){.header .nav > a{font-size:16px!important;padding-left:8px!important;padding-right:8px!important;}}

/* nav menu size all pages fix 202607011130 */
.header .nav > a{font-size:16px!important;padding-left:8px!important;padding-right:8px!important;}
@media (max-width:1024px){.header .nav > a{font-size:13px!important;padding-left:6px!important;padding-right:6px!important;}}

/* prices card compact online fix 202607011145 */
.price-list .card{min-height:0!important;padding:14px 16px 16px!important;gap:14px!important;align-items:flex-start!important;}
.price-list .card .price-card-footer{display:none!important;}
.price-list img{width:104px!important;height:104px!important;border-radius:12px!important;}
.price-list h3{font-size:23px!important;margin:0 0 4px!important;line-height:1.25!important;}
.price-list p{font-size:13px!important;line-height:1.5!important;margin:0!important;}
.price-list .price{font-size:32px!important;margin-top:10px!important;line-height:1.05!important;}
.price-list .body{gap:2px!important;}
@media (max-width:768px){.price-list .card{padding:13px!important;gap:12px!important}.price-list img{width:96px!important;height:96px!important}.price-list h3{font-size:21px!important}.price-list .price{font-size:30px!important}}

/* prices card compact hard override 202607011205 */
body:has(.hero-prices) .price-list{gap:14px!important;}
body:has(.hero-prices) .price-list .card{display:grid!important;grid-template-columns:104px minmax(0,1fr)!important;min-height:132px!important;height:auto!important;padding:14px!important;gap:14px!important;align-items:center!important;overflow:hidden!important;}
body:has(.hero-prices) .price-list .card .price-card-footer,body:has(.hero-prices) .price-card-footer{display:none!important;height:0!important;margin:0!important;padding:0!important;border:0!important;overflow:hidden!important;}
body:has(.hero-prices) .price-list img{width:104px!important;height:104px!important;min-width:104px!important;border-radius:12px!important;object-fit:cover!important;}
body:has(.hero-prices) .price-list .body{display:flex!important;flex-direction:column!important;gap:4px!important;min-height:0!important;padding:0!important;margin:0!important;}
body:has(.hero-prices) .price-list h3{font-size:22px!important;line-height:1.2!important;margin:0!important;}
body:has(.hero-prices) .price-list p{font-size:13px!important;line-height:1.35!important;margin:0!important;display:-webkit-box!important;-webkit-line-clamp:1!important;-webkit-box-orient:vertical!important;overflow:hidden!important;}
body:has(.hero-prices) .price-list .price{font-size:30px!important;line-height:1!important;margin:6px 0 0!important;}
body:has(.hero-prices) .price-list .body small{display:none!important;}
@media (max-width:768px){body:has(.hero-prices) .price-list .card{grid-template-columns:92px minmax(0,1fr)!important;min-height:118px!important;padding:12px!important;gap:12px!important}body:has(.hero-prices) .price-list img{width:92px!important;height:92px!important;min-width:92px!important}body:has(.hero-prices) .price-list h3{font-size:20px!important}body:has(.hero-prices) .price-list .price{font-size:28px!important}}

/* prices card image and text override 202607011220 */
body:has(.hero-prices) .price-list .card{
  display:flex!important;
  flex-direction:column!important;
  min-height:0!important;
  height:auto!important;
  padding:0 0 14px!important;
  gap:0!important;
  align-items:stretch!important;
  overflow:hidden!important;
}
body:has(.hero-prices) .price-list .card > img,
body:has(.hero-prices) .price-list img{
  width:100%!important;
  height:168px!important;
  min-width:0!important;
  border-radius:12px 12px 0 0!important;
  object-fit:cover!important;
  display:block!important;
}
body:has(.hero-prices) .price-list .card .body{
  padding:14px 16px 0!important;
  margin:0!important;
  gap:8px!important;
}
body:has(.hero-prices) .price-list .card .body p{
  height:22px!important;
  min-height:22px!important;
  line-height:22px!important;
  margin:0!important;
  overflow:hidden!important;
  display:-webkit-box!important;
  -webkit-line-clamp:2!important;
  -webkit-box-orient:vertical!important;
}
body:has(.hero-prices) .price-list .card .body .price{
  height:33px!important;
  margin:0!important;
  display:flex!important;
  align-items:center!important;
  gap:4px!important;
  white-space:nowrap!important;
  line-height:1!important;
}
body:has(.hero-prices) .price-list .card .price-card-footer{display:none!important;}
@media (max-width:768px){
  body:has(.hero-prices) .price-list .card > img,
  body:has(.hero-prices) .price-list img{height:150px!important;width:100%!important;}
}

/* prices remove aside and enlarge images 202607011235 */
body:has(.hero-prices) .layout{
  display:block!important;
}
body:has(.hero-prices) .layout > aside,
body:has(.hero-prices) .price-side,
body:has(.hero-prices) .side{
  display:none!important;
}
body:has(.hero-prices) .price-list{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:18px!important;
}
body:has(.hero-prices) .price-list .card{
  width:100%!important;
}
body:has(.hero-prices) .price-list .card > img,
body:has(.hero-prices) .price-list img{
  width:100%!important;
  height:220px!important;
  object-fit:cover!important;
}
@media (max-width:1024px){body:has(.hero-prices) .price-list{grid-template-columns:repeat(2,minmax(0,1fr))!important;}body:has(.hero-prices) .price-list .card > img,body:has(.hero-prices) .price-list img{height:200px!important;}}
@media (max-width:640px){body:has(.hero-prices) .price-list{grid-template-columns:1fr!important;}body:has(.hero-prices) .price-list .card > img,body:has(.hero-prices) .price-list img{height:190px!important;}}

/* header align with page container 202607011500 */
.header .container{width:min(1380px,calc(100% - 40px))!important;max-width:1380px!important;margin-left:auto!important;margin-right:auto!important;padding-left:0!important;padding-right:0!important}
@media (max-width:1024px){.header .container{width:min(100% - 24px,1240px)!important}}

/* home hero copy size reduce 202607011700 */
.hero-cover h1{font-size:42px!important;line-height:1.18!important;margin:12px 0 12px!important}
.hero-cover .lead{font-size:15px!important;line-height:1.7!important}
@media (max-width:1024px){.hero-cover h1{font-size:34px!important}.hero-cover .lead{font-size:14px!important}}
@media (max-width:768px){.hero-cover h1{font-size:30px!important}.hero-cover .lead{font-size:13px!important}}

/* news row: date + title on one line 202607011720 */
.home-news-card a,.info-card a{display:block!important;color:inherit!important}
.news-row-head{display:flex!important;align-items:center!important;gap:12px!important;flex-wrap:nowrap!important;min-width:0!important}
.news-row-head time{flex:0 0 auto!important;font-size:15px!important;font-weight:900!important;color:#4b5563!important;white-space:nowrap!important}
.home-news-card .news-row-head h3,.info-card .news-row-head h2{margin:0!important;font-size:18px!important;line-height:1.45!important;font-weight:800!important;color:#111827!important;flex:1 1 auto!important;min-width:0!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}
.home-news-card a>p,.info-card a>p{margin:10px 0 0!important;color:#6b7280!important;line-height:1.7!important}
@media (max-width:768px){.news-row-head{gap:8px!important}.news-row-head time{font-size:14px!important}.home-news-card .news-row-head h3,.info-card .news-row-head h2{font-size:16px!important}}

/* page hero copy size reduce 202607011900 */
.page-hero{min-height:220px!important}
.page-hero .container{padding:40px 0!important}
.page-hero .crumb{font-size:12px!important;margin-bottom:8px!important}
.page-hero h1{font-size:36px!important;line-height:1.2!important;margin:0 0 10px!important}
.page-hero p{font-size:14px!important;line-height:1.65!important;max-width:680px!important}
@media (max-width:1024px){.page-hero h1{font-size:30px!important}.page-hero p{font-size:13px!important}}
@media (max-width:768px){.page-hero{min-height:190px!important}.page-hero .container{padding:32px 0!important}.page-hero h1{font-size:26px!important}.page-hero p{font-size:13px!important}.page-hero .crumb{font-size:11px!important}}

/* contact line qr card 202607011930 */
.contact-side a.contact-line-qr-card{display:grid!important;gap:12px!important;padding:20px 18px 18px!important;margin:0!important;border-top:1px solid #eceff4!important;background:linear-gradient(180deg,#06c755 0%,#00a946 100%)!important;color:#fff!important;text-decoration:none!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.16)!important;position:relative!important;overflow:hidden!important;font-size:16px!important;font-weight:700!important;line-height:1.5!important}
.contact-side a.contact-line-qr-card::after{content:""!important;position:absolute!important;right:-28px!important;bottom:-34px!important;width:110px!important;height:110px!important;border-radius:50%!important;background:rgba(255,255,255,.14)!important;pointer-events:none!important}
.contact-line-qr-badge{display:inline-flex!important;align-self:flex-start!important;align-items:center!important;justify-content:center!important;min-width:52px!important;padding:4px 10px!important;border-radius:999px!important;background:rgba(255,255,255,.18)!important;border:1px solid rgba(255,255,255,.28)!important;font-size:12px!important;font-weight:900!important;letter-spacing:.08em!important;position:relative!important;z-index:1!important;color:#fff!important}
.contact-side a.contact-line-qr-card strong{display:block!important;font-size:18px!important;line-height:1.45!important;font-weight:900!important;color:#fff!important;position:relative!important;z-index:1!important}
.contact-line-qr-image{display:block!important;padding:10px!important;background:#fff!important;border-radius:12px!important;box-shadow:0 8px 20px rgba(0,0,0,.12)!important;position:relative!important;z-index:1!important;line-height:0!important}
.contact-line-qr-image img{display:block!important;width:100%!important;height:auto!important}
.contact-side a.contact-line-qr-card small{display:block!important;font-size:13px!important;font-weight:700!important;color:rgba(255,255,255,.92)!important;position:relative!important;z-index:1!important;padding:0!important;border:0!important;background:transparent!important}
@media (max-width:768px){.contact-side a.contact-line-qr-card strong{font-size:16px!important}}

/* price down arrow hide 202607012000 */
.price.trend-down .price-arrow,.price-detail-value.trend-down .price-arrow,.price-list .card .price.trend-down .price-arrow,.price-tile .price.trend-down .price-arrow{display:none!important}

/* price detail value size reduce 202607012010 */
.price-detail-value{align-items:baseline!important;gap:8px!important;line-height:1.2!important;margin:0 0 24px!important;padding-bottom:4px!important}
.price-detail-value strong{font-size:32px!important;font-weight:900!important;letter-spacing:0!important;line-height:1.2!important}
.price-detail-value span{font-size:18px!important;font-weight:800!important;padding-bottom:0!important}
.price-detail-value .price-arrow{font-size:22px!important;margin-left:6px!important;vertical-align:baseline!important}
@media (max-width:768px){.price-detail-value strong{font-size:26px!important}.price-detail-value span{font-size:16px!important}.price-detail-value .price-arrow{font-size:18px!important}}

/* mobile viewport lock 202607021030 */
@media (max-width:768px){
  html,body{width:100%!important;max-width:100%!important;overflow-x:hidden!important}
  body{min-width:0!important}
  .header,.page-hero,.hero-cover,.footer,.mobile-drawer,.drawer-backdrop,.mobile-fixed{max-width:100%!important}
  .container,.header .container,.hero-cover .container,.page-hero .container,.footer .container{
    width:calc(100% - 24px)!important;
    max-width:100%!important;
    margin-left:auto!important;
    margin-right:auto!important;
    box-sizing:border-box!important;
  }
  .brand{min-width:0!important;max-width:calc(100% - 72px)!important}
  .header-inner{gap:12px!important}
  .page-hero,.hero-cover{overflow:hidden!important}
  .section,.section.alt,.info-layout,.layout,.detail-wrap,.footer-grid,.prices-categories,.prices-products-grid{
    max-width:100%!important;
  }
  .reveal,.reveal.is-visible{transform:none!important}
  html,body{touch-action:manipulation!important;-ms-touch-action:manipulation!important}
}

/* price detail anchor scroll 202607012020 */
html:has(#price-product-detail){scroll-behavior:smooth}
#price-product-detail{scroll-margin-top:100px}
