/* ===== RESET & BASE ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Shippori Mincho','Noto Serif JP',serif;color:#1A1A1A;background:#FEFEFE;line-height:1.8;overflow-x:hidden}
a{text-decoration:none;color:inherit;transition:all .3s ease}
img{max-width:100%;height:auto;display:block}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,textarea,select{font-family:inherit;font-size:1rem}

/* ===== UTILITIES ===== */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.section{padding:120px 0}
.section-label{font-size:.75rem;letter-spacing:.3em;text-transform:uppercase;color:#B8956A;margin-bottom:12px;font-weight:600}
.section-title{font-size:2.5rem;font-weight:700;margin-bottom:24px;line-height:1.3}
.section-desc{font-size:1.1rem;color:#555;max-width:640px;margin-bottom:60px}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:16px 40px;font-size:1rem;font-weight:600;border-radius:2px;transition:all .3s ease;letter-spacing:.05em}
.btn-primary{background:#B8956A;color:#fff}
.btn-primary:hover{background:#9E7B55;transform:translateY(-2px);box-shadow:0 8px 24px rgba(184,149,106,.3)}
.btn-outline{border:1px solid #fff;color:#fff}
.btn-outline:hover{background:#fff;color:#1A1A1A}
.btn-full{width:100%}
.required{color:#B8956A;font-size:.75rem;margin-left:4px}

/* ===== HEADER ===== */
.header{position:fixed;top:0;left:0;width:100%;z-index:1000;background:transparent;transition:all .4s ease}
.header.scrolled{background:rgba(26,26,26,.95);backdrop-filter:blur(10px)}
.header-inner{max-width:1400px;margin:0 auto;padding:0 32px;display:flex;align-items:center;justify-content:space-between;height:80px}
.logo{display:flex;align-items:center;gap:12px}
.logo-text{font-size:1.25rem;font-weight:700;color:#fff;letter-spacing:.05em}
.header.scrolled .logo-text{color:#fff}
.nav{display:flex;align-items:center;gap:32px}
.nav-link{font-size:.875rem;color:rgba(255,255,255,.8);letter-spacing:.05em;position:relative;font-weight:500}
.nav-link:hover{color:#B8956A}
.nav-link::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:#B8956A;transition:width .3s ease}
.nav-link:hover::after{width:100%}
.nav-cta{padding:8px 24px;border:1px solid #B8956A;color:#B8956A}
.nav-cta:hover{background:#B8956A;color:#fff}
.nav-cta::after{display:none}

.hamburger{display:none;flex-direction:column;gap:6px;width:28px;padding:4px 0}
.hamburger span{display:block;height:1px;background:#fff;transition:all .3s ease}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== HERO ===== */
.hero{position:relative;height:100vh;min-height:700px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(26,26,26,.85) 0%,rgba(26,26,26,.6) 50%,rgba(26,26,26,.75) 100%)}
.hero-content{position:relative;z-index:2;text-align:center;color:#fff;padding:0 24px}
.hero-sub{font-size:.875rem;letter-spacing:.4em;color:#B8956A;margin-bottom:24px;font-weight:600}
.hero-title{font-size:4rem;font-weight:800;line-height:1.3;margin-bottom:24px;letter-spacing:.05em}
.hero-desc{font-size:1.125rem;color:rgba(255,255,255,.7);margin-bottom:48px;line-height:2}
.hero-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:12px;color:rgba(255,255,255,.5);font-size:.7rem;letter-spacing:.2em}
.scroll-line{width:1px;height:40px;background:rgba(255,255,255,.3);position:relative;overflow:hidden}
.scroll-line::after{content:'';position:absolute;top:-100%;left:0;width:100%;height:100%;background:#B8956A;animation:scrollDown 2s ease infinite}
@keyframes scrollDown{0%{top:-100%}100%{top:100%}}

/* ===== ABOUT ===== */
.about{background:#FEFEFE}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-image{position:relative}
.about-image img{width:100%;aspect-ratio:4/3;object-fit:cover}
.about-image::after{content:'';position:absolute;top:20px;left:20px;right:-20px;bottom:-20px;border:1px solid #B8956A;z-index:-1}
.about-text h3{font-size:1.75rem;margin-bottom:24px;line-height:1.5}
.about-text p{color:#555;margin-bottom:16px}
.about-signature{margin-top:32px;padding-top:24px;border-top:1px solid #E5E0DA}
.sig-title{font-size:.875rem;color:#888}
.sig-name{font-size:1.5rem;font-weight:700;margin-top:4px}

/* ===== SERVICES ===== */
.services{background:#F7F5F2}
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:40px}
.service-card{background:#fff;padding:48px;border:1px solid #E5E0DA;transition:all .4s ease;position:relative;overflow:hidden}
.service-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:0;background:#B8956A;transition:height .4s ease}
.service-card:hover::before{height:100%}
.service-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.08)}
.service-number{font-size:3rem;font-weight:800;color:rgba(184,149,106,.15);margin-bottom:16px;line-height:1}
.service-title{font-size:1.375rem;font-weight:700;margin-bottom:16px}
.service-desc{color:#555;font-size:.95rem;margin-bottom:24px}
.service-list li{padding:6px 0;padding-left:20px;position:relative;color:#555;font-size:.9rem}
.service-list li::before{content:'';position:absolute;left:0;top:14px;width:8px;height:1px;background:#B8956A}

/* ===== STRENGTH ===== */
.strength{background:#1A1A1A;color:#fff}
.strength .section-title{color:#fff}
.strength-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:60px}
.strength-item{padding:40px;border:1px solid rgba(184,149,106,.2);transition:all .3s ease}
.strength-item:hover{border-color:#B8956A;background:rgba(184,149,106,.05)}
.strength-icon{margin-bottom:24px}
.strength-item h3{font-size:1.25rem;margin-bottom:16px;font-weight:600}
.strength-item p{color:rgba(255,255,255,.6);font-size:.95rem}

/* ===== CASES ===== */
.cases{background:#FEFEFE}
.cases-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.case-card{background:#fff;border:1px solid #E5E0DA;padding:40px;transition:all .3s ease}
.case-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(0,0,0,.06)}
.case-tag{display:inline-block;padding:4px 16px;background:#B8956A;color:#fff;font-size:.75rem;margin-bottom:20px;letter-spacing:.1em}
.case-title{font-size:1.125rem;font-weight:700;margin-bottom:20px;line-height:1.5}
.case-detail{display:flex;flex-direction:column;gap:16px}
.case-row{display:flex;gap:12px}
.case-label{flex-shrink:0;font-size:.75rem;padding:2px 8px;background:#F7F5F2;color:#888;height:fit-content;margin-top:4px}
.case-row p{font-size:.9rem;color:#555}

/* ===== NUMBERS ===== */
.numbers{background:#F7F5F2;padding:80px 0}
.numbers-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;text-align:center}
.number-value{font-size:3.5rem;font-weight:800;color:#B8956A;line-height:1}
.number-unit{font-size:1.25rem;color:#B8956A;margin-top:4px}
.number-label{font-size:.875rem;color:#888;margin-top:12px}

/* ===== FLOW ===== */
.flow{background:#FEFEFE}
.flow-steps{max-width:800px;margin:0 auto;position:relative}
.flow-steps::before{content:'';position:absolute;left:24px;top:0;bottom:0;width:1px;background:#E5E0DA}
.flow-step{padding-left:72px;padding-bottom:48px;position:relative}
.flow-step:last-child{padding-bottom:0}
.flow-number{position:absolute;left:0;top:0;width:49px;height:49px;display:flex;align-items:center;justify-content:center;background:#B8956A;color:#fff;font-size:.875rem;font-weight:700}
.flow-step h3{font-size:1.25rem;font-weight:700;margin-bottom:12px}
.flow-step p{color:#555;font-size:.95rem}

/* ===== FAQ ===== */
.faq{background:#F7F5F2}
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border-bottom:1px solid #E5E0DA}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;padding:24px 0;font-size:1.05rem;font-weight:600;text-align:left;gap:16px}
.faq-arrow{flex-shrink:0;transition:transform .3s ease;color:#B8956A}
.faq-item.active .faq-arrow{transform:rotate(180deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-answer p{padding-bottom:24px;color:#555;font-size:.95rem;line-height:2}

/* ===== COMPANY ===== */
.company{background:#FEFEFE}
.company-table-wrap{max-width:800px;margin:0 auto 60px}
.company-table{width:100%;border-collapse:collapse}
.company-table tr{border-bottom:1px solid #E5E0DA}
.company-table th{padding:20px 24px;text-align:left;font-weight:600;width:200px;font-size:.95rem;vertical-align:top;color:#888}
.company-table td{padding:20px 24px;font-size:.95rem}
.company-map{max-width:800px;margin:0 auto}
.company-map img{width:100%;aspect-ratio:16/7;object-fit:cover}

/* ===== CONTACT ===== */
.contact{background:#1A1A1A;color:#fff}
.contact .section-title{color:#fff}
.contact .section-desc{color:rgba(255,255,255,.6)}
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:60px;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:32px}
.contact-box{padding:32px;border:1px solid rgba(184,149,106,.3);background:rgba(255,255,255,.03)}
.contact-box h3{font-size:1rem;margin-bottom:12px;color:#B8956A}
.contact-tel{font-size:2rem;font-weight:700}
.contact-email{font-size:1.125rem}
.contact-hours{font-size:.85rem;color:rgba(255,255,255,.5);margin-top:8px}
.contact-form{display:flex;flex-direction:column;gap:24px}
.form-group{display:flex;flex-direction:column;gap:8px}
.form-group label{font-size:.875rem;color:rgba(255,255,255,.7)}
.form-group input,.form-group textarea,.form-group select{padding:14px 16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.15);color:#fff;border-radius:2px;transition:border-color .3s ease}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#B8956A}
.form-group select{appearance:none}
.form-group select option{background:#1A1A1A;color:#fff}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}

/* ===== FOOTER ===== */
.footer{background:#111;color:rgba(255,255,255,.6);padding:80px 0 40px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:60px}
.footer-brand .logo-text{color:#fff}
.footer-desc{font-size:.875rem;margin-top:16px;line-height:1.8}
.footer-links h4{font-size:.875rem;color:#fff;margin-bottom:16px;font-weight:600}
.footer-links a,.footer-links p{display:block;font-size:.85rem;margin-bottom:8px;transition:color .3s ease;line-height:1.6}
.footer-links a:hover{color:#B8956A}
.footer-bottom{padding-top:40px;border-top:1px solid rgba(255,255,255,.1);text-align:center;font-size:.8rem}

/* ===== ANIMATIONS ===== */
.fade-in{opacity:0;transform:translateY(30px);transition:all .8s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .hero-title{font-size:3rem}
  .section-title{font-size:2rem}
  .services-grid{grid-template-columns:1fr}
  .cases-grid{grid-template-columns:1fr}
  .strength-grid{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr;gap:40px}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .numbers-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:768px){
  .section{padding:80px 0}
  .hero-title{font-size:2.25rem}
  .hero-desc{font-size:1rem}
  .nav{display:none;position:fixed;top:0;left:0;width:100%;height:100vh;background:rgba(26,26,26,.98);flex-direction:column;justify-content:center;align-items:center;gap:24px}
  .nav.active{display:flex}
  .nav-link{font-size:1.25rem;color:#fff}
  .hamburger{display:flex}
  .service-card{padding:32px}
  .case-card{padding:28px}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .company-table th{display:block;width:100%;padding-bottom:4px}
  .company-table td{display:block;padding-top:4px;padding-bottom:20px}
  .numbers-grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .number-value{font-size:2.5rem}
  .about-image::after{display:none}
  .hero{min-height:600px}
  .header-inner{height:64px;padding:0 16px}
}

@media(max-width:480px){
  .hero-title{font-size:1.75rem}
  .section-title{font-size:1.5rem}
  .btn{padding:14px 28px;font-size:.9rem}
  .hero-actions{flex-direction:column;align-items:center}
  .number-value{font-size:2rem}
}

/* ===== TESTIMONIALS ===== */
.testimonials{background:#FEFEFE}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.testimonial-card{background:#F7F5F2;padding:32px;border-radius:8px;border:1px solid #E5E0DA;transition:all .3s ease}
.testimonial-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.06)}
.testimonial-stars{display:flex;gap:4px;margin-bottom:16px}
.testimonial-text{font-size:.9rem;color:#1A1A1A;opacity:.7;margin-bottom:20px;line-height:1.9}
.testimonial-meta{display:flex;flex-direction:column;gap:4px}
.testimonial-name{font-size:.9rem;font-weight:700;color:#1A1A1A}
.testimonial-detail{font-size:.8rem;color:#B8956A;opacity:.7}

/* ===== PRICE ===== */
.price{background:#F7F5F2}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.price-card{background:#FEFEFE;padding:36px;border-radius:8px;border:1px solid #E5E0DA;transition:all .3s ease;text-align:center}
.price-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.06)}
.price-name{font-size:1.1rem;font-weight:700;margin-bottom:16px;color:#1A1A1A}
.price-amount{font-size:2.5rem;font-weight:800;color:#B8956A;margin-bottom:12px;line-height:1}
.price-yen{font-size:1.5rem;vertical-align:top}
.price-tax{font-size:.8rem;font-weight:400;color:#1A1A1A;opacity:.5}
.price-note{font-size:.85rem;color:#1A1A1A;opacity:.5;margin-bottom:20px;text-align:left}
.price-includes{text-align:left}
.price-includes li{padding:6px 0;padding-left:20px;position:relative;font-size:.85rem;color:#1A1A1A;opacity:.6}
.price-includes li::before{content:'';position:absolute;left:0;top:14px;width:8px;height:2px;background:#B8956A}

/* ===== CTA BANNER ===== */
.cta-banner{background:#B8956A;padding:80px 0;color:#fff}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}
.cta-text h2{font-size:1.75rem;font-weight:700;margin-bottom:8px;line-height:1.5}
.cta-text p{font-size:1rem;opacity:.8}
.cta-actions{display:flex;gap:16px;flex-wrap:wrap}
.cta-banner .btn-primary{background:#fff;color:#B8956A}
.cta-banner .btn-primary:hover{background:rgba(255,255,255,.9);transform:translateY(-2px)}
.cta-banner .btn-outline{border-color:rgba(255,255,255,.5);color:#fff}
.cta-banner .btn-outline:hover{background:rgba(255,255,255,.1)}

/* ===== EXTENDED RESPONSIVE ===== */
@media(max-width:1024px){
  .testimonials-grid{grid-template-columns:1fr}
  .price-grid{grid-template-columns:1fr}
  .cta-inner{flex-direction:column;text-align:center}
  .cta-actions{justify-content:center}
}
@media(max-width:768px){
  .testimonial-card{padding:24px}
  .price-card{padding:28px}
  .price-amount{font-size:2rem}
  .cta-text h2{font-size:1.35rem}
  .cta-banner{padding:60px 0}
}
@media(max-width:480px){
  .price-amount{font-size:1.75rem}
  .cta-actions{flex-direction:column;align-items:center}
}

/* ===== ADDITIONAL UTILITY CLASSES ===== */
.text-center{text-align:center}
.text-left{text-align:left}
.text-right{text-align:right}
.mx-auto{margin-left:auto;margin-right:auto}
.mb-0{margin-bottom:0}
.mb-8{margin-bottom:8px}
.mb-16{margin-bottom:16px}
.mb-24{margin-bottom:24px}
.mb-32{margin-bottom:32px}
.mb-48{margin-bottom:48px}
.mb-64{margin-bottom:64px}
.mt-0{margin-top:0}
.mt-8{margin-top:8px}
.mt-16{margin-top:16px}
.mt-24{margin-top:24px}
.mt-32{margin-top:32px}
.mt-48{margin-top:48px}
.pt-0{padding-top:0}
.pt-16{padding-top:16px}
.pt-24{padding-top:24px}
.pt-32{padding-top:32px}
.pt-48{padding-top:48px}
.pb-0{padding-bottom:0}
.pb-16{padding-bottom:16px}
.pb-24{padding-bottom:24px}
.pb-32{padding-bottom:32px}
.pb-48{padding-bottom:48px}
.gap-8{gap:8px}
.gap-16{gap:16px}
.gap-24{gap:24px}
.gap-32{gap:32px}
.gap-48{gap:48px}
.flex{display:flex}
.flex-col{flex-direction:column}
.flex-wrap{flex-wrap:wrap}
.items-center{align-items:center}
.justify-center{justify-content:center}
.justify-between{justify-content:space-between}
.grid{display:grid}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.w-full{width:100%}
.max-w-sm{max-width:480px}
.max-w-md{max-width:640px}
.max-w-lg{max-width:800px}
.max-w-xl{max-width:1024px}
.hidden{display:none}
.block{display:block}
.inline-block{display:inline-block}
.relative{position:relative}
.absolute{position:absolute}
.overflow-hidden{overflow:hidden}
.rounded{border-radius:4px}
.rounded-lg{border-radius:8px}
.rounded-xl{border-radius:16px}
.rounded-full{border-radius:9999px}
.shadow-sm{box-shadow:0 1px 2px rgba(0,0,0,.05)}
.shadow{box-shadow:0 4px 6px rgba(0,0,0,.07)}
.shadow-md{box-shadow:0 8px 16px rgba(0,0,0,.1)}
.shadow-lg{box-shadow:0 16px 32px rgba(0,0,0,.12)}
.shadow-xl{box-shadow:0 24px 48px rgba(0,0,0,.15)}
.opacity-0{opacity:0}
.opacity-50{opacity:.5}
.opacity-75{opacity:.75}
.opacity-100{opacity:1}
.transition{transition:all .3s ease}
.transition-fast{transition:all .15s ease}
.transition-slow{transition:all .5s ease}
.cursor-pointer{cursor:pointer}
.select-none{user-select:none}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}

/* ===== EXTENDED TYPOGRAPHY ===== */
.text-xs{font-size:.75rem}
.text-sm{font-size:.875rem}
.text-base{font-size:1rem}
.text-lg{font-size:1.125rem}
.text-xl{font-size:1.25rem}
.text-2xl{font-size:1.5rem}
.text-3xl{font-size:2rem}
.text-4xl{font-size:2.5rem}
.text-5xl{font-size:3rem}
.font-light{font-weight:300}
.font-normal{font-weight:400}
.font-medium{font-weight:500}
.font-semibold{font-weight:600}
.font-bold{font-weight:700}
.font-extrabold{font-weight:800}
.font-black{font-weight:900}
.leading-tight{line-height:1.25}
.leading-normal{line-height:1.5}
.leading-relaxed{line-height:1.75}
.leading-loose{line-height:2}
.tracking-tight{letter-spacing:-.025em}
.tracking-normal{letter-spacing:0}
.tracking-wide{letter-spacing:.025em}
.tracking-wider{letter-spacing:.05em}
.tracking-widest{letter-spacing:.1em}
.uppercase{text-transform:uppercase}
.lowercase{text-transform:lowercase}
.capitalize{text-transform:capitalize}
.underline{text-decoration:underline}
.no-underline{text-decoration:none}
.italic{font-style:italic}

/* ===== EXTENDED COMPONENT STYLES ===== */
.badge{display:inline-flex;align-items:center;padding:4px 12px;font-size:.75rem;font-weight:600;border-radius:4px}
.badge-primary{background:#B8956A;color:#fff}
.badge-outline{border:1px solid #B8956A;color:#B8956A}
.divider{width:100%;height:1px;background:#E5E0DA;margin:40px 0}
.divider-vertical{width:1px;height:40px;background:#E5E0DA;margin:0 20px}
.icon-sm{width:16px;height:16px}
.icon-md{width:24px;height:24px}
.icon-lg{width:32px;height:32px}
.icon-xl{width:48px;height:48px}
.avatar{width:48px;height:48px;border-radius:50%;object-fit:cover}
.avatar-lg{width:72px;height:72px}
.avatar-xl{width:96px;height:96px}
.card{background:#FEFEFE;border:1px solid #E5E0DA;border-radius:8px;padding:24px;transition:all .3s ease}
.card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.06)}
.card-header{padding-bottom:16px;margin-bottom:16px;border-bottom:1px solid #E5E0DA}
.card-body{padding:0}
.card-footer{padding-top:16px;margin-top:16px;border-top:1px solid #E5E0DA}
.tag{display:inline-flex;align-items:center;padding:2px 8px;font-size:.7rem;font-weight:600;border-radius:3px;background:rgba(0,0,0,.05)}
.tooltip{position:relative;cursor:help}
.tooltip::after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);padding:8px 12px;background:#333;color:#fff;font-size:.75rem;border-radius:4px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease}
.tooltip:hover::after{opacity:1}
.progress{width:100%;height:8px;background:#E5E0DA;border-radius:4px;overflow:hidden}
.progress-bar{height:100%;background:#B8956A;border-radius:4px;transition:width .6s ease}
.skeleton{background:linear-gradient(90deg,#E5E0DA 25%,transparent 50%,#E5E0DA 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.alert{padding:16px 20px;border-radius:8px;font-size:.9rem;margin-bottom:16px}
.alert-info{background:rgba(6,182,212,.1);border:1px solid rgba(6,182,212,.2);color:#0891B2}
.alert-success{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.2);color:#16A34A}
.alert-warning{background:rgba(234,179,8,.1);border:1px solid rgba(234,179,8,.2);color:#CA8A04}
.alert-error{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.2);color:#DC2626}

/* ===== SCROLL ANIMATIONS ===== */
.slide-in-left{opacity:0;transform:translateX(-40px);transition:all .7s ease}
.slide-in-left.visible{opacity:1;transform:translateX(0)}
.slide-in-right{opacity:0;transform:translateX(40px);transition:all .7s ease}
.slide-in-right.visible{opacity:1;transform:translateX(0)}
.scale-in{opacity:0;transform:scale(.9);transition:all .6s ease}
.scale-in.visible{opacity:1;transform:scale(1)}
.blur-in{opacity:0;filter:blur(8px);transition:all .8s ease}
.blur-in.visible{opacity:1;filter:blur(0)}

/* ===== HOVER EFFECTS ===== */
.hover-lift:hover{transform:translateY(-4px)}
.hover-glow:hover{box-shadow:0 0 20px rgba(#B8956A,.3)}
.hover-scale:hover{transform:scale(1.02)}
.hover-border:hover{border-color:#B8956A}
.hover-bg:hover{background:rgba(0,0,0,.02)}

/* ===== EXTENDED MEDIA QUERIES ===== */
@media(min-width:1440px){
  .container{max-width:1320px}
  .hero-title{font-size:5rem}
  .section-title{font-size:3rem}
  .section{padding:140px 0}
}
@media(min-width:1920px){
  .container{max-width:1440px}
  body{font-size:18px}
}
@media(max-width:360px){
  .hero-title{font-size:1.5rem}
  .section-title{font-size:1.25rem}
  .container{padding:0 16px}
  .btn{padding:12px 20px;font-size:.85rem}
  .service-card{padding:20px}
  .header-inner{padding:0 12px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.01ms!important}
  .scroll-line::after{animation:none}
}
@media(prefers-color-scheme:dark){
  /* Dark mode overrides can be added here */
}
@media print{
  .header,.hero-scroll,.hamburger,.nav-cta,.cta-banner,.contact-form{display:none}
  .hero{height:auto;min-height:auto;page-break-after:always}
  .section{padding:40px 0;page-break-inside:avoid}
  body{font-size:12pt;line-height:1.6;color:#000;background:#fff}
  a{color:#000}
  .hero-overlay{background:rgba(255,255,255,.8)}
}

/* ===== KEYFRAMES ===== */
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInDown{from{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInLeft{from{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}
@keyframes fadeInRight{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes slideUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes slideDown{from{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes scaleUp{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes ripple{0%{transform:scale(0);opacity:.6}100%{transform:scale(4);opacity:0}}
.animate-fadeInUp{animation:fadeInUp .6s ease forwards}
.animate-fadeInDown{animation:fadeInDown .6s ease forwards}
.animate-fadeInLeft{animation:fadeInLeft .6s ease forwards}
.animate-fadeInRight{animation:fadeInRight .6s ease forwards}
.animate-pulse{animation:pulse 2s ease infinite}
.animate-bounce{animation:bounce 1s ease infinite}
.animate-spin{animation:spin 1s linear infinite}

/* ===== INFO LIST ===== */
.additional-info{background:#FEFEFE}
.info-list{max-width:800px;margin:0 auto}
.info-item{display:flex;align-items:center;gap:16px;padding:20px 0;border-bottom:1px solid #E5E0DA;flex-wrap:wrap}
.info-date{font-size:.8rem;color:#1A1A1A;opacity:.5;white-space:nowrap;min-width:80px}
.info-tag{display:inline-block;padding:2px 12px;background:#B8956A;color:#fff;font-size:.7rem;font-weight:600;border-radius:3px;white-space:nowrap}
.info-text{font-size:.9rem;color:#1A1A1A;opacity:.7;flex:1;min-width:200px}
@media(max-width:768px){
  .info-item{flex-direction:column;align-items:flex-start;gap:8px}
  .info-text{min-width:auto}
}

/* ===== PARTNERS ===== */
.partners{background:#F7F5F2}
.partners-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.partner-item{padding:28px;background:#FEFEFE;border:1px solid #E5E0DA;border-radius:8px;transition:all .3s ease}
.partner-item:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.05)}
.partner-item h3{font-size:1rem;font-weight:700;margin-bottom:8px;color:#1A1A1A}
.partner-item p{font-size:.85rem;color:#1A1A1A;opacity:.5;line-height:1.7}
@media(max-width:1024px){
  .partners-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .partners-grid{grid-template-columns:1fr}
  .partner-item{padding:20px}
}

/* ===== BREADCRUMB ===== */
.breadcrumb{padding:12px 0;font-size:.8rem}
.breadcrumb a{color:#B8956A}
.breadcrumb span{color:#1A1A1A;opacity:.4;margin:0 8px}

/* ===== TABLE VARIANTS ===== */
.table-striped tr:nth-child(even){background:rgba(0,0,0,.02)}
.table-bordered{border:1px solid #E5E0DA}
.table-bordered th,.table-bordered td{border:1px solid #E5E0DA}
.table-sm th,.table-sm td{padding:8px 12px}
.table-hover tr:hover{background:rgba(0,0,0,.03)}

/* ===== LIST STYLES ===== */
.list-disc li{list-style:disc;margin-left:20px;margin-bottom:8px}
.list-decimal li{list-style:decimal;margin-left:20px;margin-bottom:8px}
.list-check li{padding-left:24px;position:relative;margin-bottom:8px}
.list-check li::before{content:'';position:absolute;left:2px;top:8px;width:12px;height:6px;border-left:2px solid #B8956A;border-bottom:2px solid #B8956A;transform:rotate(-45deg)}

/* ===== FORM VARIANTS ===== */
.form-inline{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}
.form-inline .form-group{flex:1;min-width:200px}
.input-sm{padding:8px 12px;font-size:.85rem}
.input-lg{padding:18px 20px;font-size:1.1rem}
.input-error{border-color:#DC2626!important}
.input-success{border-color:#16A34A!important}
.form-help{font-size:.75rem;color:#1A1A1A;opacity:.4;margin-top:4px}
.form-error{font-size:.75rem;color:#DC2626;margin-top:4px}
.checkbox-group{display:flex;flex-direction:column;gap:12px}
.checkbox-label{display:flex;align-items:center;gap:8px;font-size:.9rem;cursor:pointer}
.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:#B8956A}
.radio-group{display:flex;flex-direction:column;gap:12px}
.radio-label{display:flex;align-items:center;gap:8px;font-size:.9rem;cursor:pointer}
.radio-label input[type=radio]{width:18px;height:18px;accent-color:#B8956A}

/* ===== MODAL ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:2000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease}
.modal-overlay.active{opacity:1;pointer-events:auto}
.modal{background:#FEFEFE;border-radius:12px;max-width:560px;width:90%;max-height:85vh;overflow-y:auto;padding:40px;position:relative}
.modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#1A1A1A;opacity:.5;transition:opacity .2s}
.modal-close:hover{opacity:1}
.modal h2{font-size:1.5rem;font-weight:700;margin-bottom:16px}
.modal p{font-size:.95rem;color:#1A1A1A;opacity:.7;margin-bottom:16px}

/* ===== TABS ===== */
.tabs{display:flex;gap:0;border-bottom:1px solid #E5E0DA;margin-bottom:32px}
.tab{padding:12px 24px;font-size:.9rem;font-weight:600;color:#1A1A1A;opacity:.5;cursor:pointer;border-bottom:2px solid transparent;transition:all .3s ease;background:none;border-top:none;border-left:none;border-right:none}
.tab:hover{opacity:.8}
.tab.active{opacity:1;color:#B8956A;border-bottom-color:#B8956A}
.tab-content{display:none}
.tab-content.active{display:block}

/* ===== ACCORDION VARIANT ===== */
.accordion{border:1px solid #E5E0DA;border-radius:8px;overflow:hidden}
.accordion-item{border-bottom:1px solid #E5E0DA}
.accordion-item:last-child{border-bottom:none}
.accordion-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:16px 20px;font-size:.95rem;font-weight:600;background:none;border:none;cursor:pointer;color:#1A1A1A;text-align:left}
.accordion-body{padding:0 20px;max-height:0;overflow:hidden;transition:max-height .3s ease}
.accordion-body-inner{padding-bottom:16px;font-size:.9rem;color:#1A1A1A;opacity:.6}

/* ===== TIMELINE ===== */
.timeline{position:relative;padding-left:40px}
.timeline::before{content:'';position:absolute;left:15px;top:0;bottom:0;width:2px;background:#E5E0DA}
.timeline-item{position:relative;padding-bottom:32px}
.timeline-item:last-child{padding-bottom:0}
.timeline-dot{position:absolute;left:-33px;top:4px;width:12px;height:12px;border-radius:50%;background:#B8956A}
.timeline-date{font-size:.8rem;color:#B8956A;font-weight:600;margin-bottom:4px}
.timeline-title{font-size:1rem;font-weight:700;color:#1A1A1A;margin-bottom:4px}
.timeline-desc{font-size:.9rem;color:#1A1A1A;opacity:.6}

/* ===== STATS CARD ===== */
.stats-row{display:flex;gap:24px;flex-wrap:wrap}
.stat-card{flex:1;min-width:200px;padding:24px;background:#F7F5F2;border:1px solid #E5E0DA;border-radius:8px;text-align:center}
.stat-card-value{font-size:2rem;font-weight:800;color:#B8956A;margin-bottom:4px}
.stat-card-label{font-size:.8rem;color:#1A1A1A;opacity:.5}
.stat-card-change{font-size:.75rem;margin-top:4px}
.stat-card-change.up{color:#16A34A}
.stat-card-change.down{color:#DC2626}

/* ===== NOTIFICATION ===== */
.notification{position:fixed;top:20px;right:20px;z-index:3000;padding:16px 24px;border-radius:8px;font-size:.9rem;color:#fff;transform:translateX(calc(100% + 40px));transition:transform .4s ease;max-width:380px}
.notification.show{transform:translateX(0)}
.notification-success{background:#16A34A}
.notification-error{background:#DC2626}
.notification-info{background:#0891B2}

/* ===== LOADING ===== */
.loading{display:flex;align-items:center;justify-content:center;padding:40px}
.spinner{width:40px;height:40px;border:3px solid #E5E0DA;border-top-color:#B8956A;border-radius:50%;animation:spin 1s linear infinite}
.spinner-sm{width:20px;height:20px;border-width:2px}
.spinner-lg{width:60px;height:60px;border-width:4px}

/* ===== BACK TO TOP ===== */
.back-to-top{position:fixed;bottom:24px;right:24px;width:48px;height:48px;background:#B8956A;color:#fff;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transform:translateY(20px);transition:all .3s ease;z-index:900;box-shadow:0 4px 12px rgba(0,0,0,.15)}
.back-to-top.visible{opacity:1;transform:translateY(0)}
.back-to-top:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.back-to-top svg{width:20px;height:20px}

/* ===== COOKIE BANNER ===== */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:#FEFEFE;border-top:1px solid #E5E0DA;padding:20px 24px;z-index:1500;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;box-shadow:0 -4px 20px rgba(0,0,0,.1)}
.cookie-text{font-size:.85rem;color:#1A1A1A;opacity:.7;flex:1;min-width:200px}
.cookie-actions{display:flex;gap:12px}

/* ===== IMAGE STYLES ===== */
.img-rounded{border-radius:8px}
.img-circle{border-radius:50%}
.img-cover{object-fit:cover;width:100%;height:100%}
.img-contain{object-fit:contain}
.img-grayscale{filter:grayscale(100%);transition:filter .3s ease}
.img-grayscale:hover{filter:grayscale(0)}
.img-zoom{transition:transform .4s ease}
.img-zoom:hover{transform:scale(1.05)}
.aspect-square{aspect-ratio:1/1}
.aspect-video{aspect-ratio:16/9}
.aspect-portrait{aspect-ratio:3/4}

/* ===== GRID SYSTEM ===== */
.row{display:flex;flex-wrap:wrap;margin:0 -12px}
.col{flex:1;padding:0 12px}
.col-auto{flex:0 0 auto;padding:0 12px}
.col-1{flex:0 0 8.333%;max-width:8.333%;padding:0 12px}
.col-2{flex:0 0 16.667%;max-width:16.667%;padding:0 12px}
.col-3{flex:0 0 25%;max-width:25%;padding:0 12px}
.col-4{flex:0 0 33.333%;max-width:33.333%;padding:0 12px}
.col-5{flex:0 0 41.667%;max-width:41.667%;padding:0 12px}
.col-6{flex:0 0 50%;max-width:50%;padding:0 12px}
.col-7{flex:0 0 58.333%;max-width:58.333%;padding:0 12px}
.col-8{flex:0 0 66.667%;max-width:66.667%;padding:0 12px}
.col-9{flex:0 0 75%;max-width:75%;padding:0 12px}
.col-10{flex:0 0 83.333%;max-width:83.333%;padding:0 12px}
.col-11{flex:0 0 91.667%;max-width:91.667%;padding:0 12px}
.col-12{flex:0 0 100%;max-width:100%;padding:0 12px}
@media(max-width:768px){
  .col-md-12{flex:0 0 100%;max-width:100%}
  .col-md-6{flex:0 0 50%;max-width:50%}
}
@media(max-width:480px){
  .col-sm-12{flex:0 0 100%;max-width:100%}
}

/* ===== SPACING UTILITIES ===== */
.p-0{padding:0}.p-4{padding:4px}.p-8{padding:8px}.p-12{padding:12px}.p-16{padding:16px}.p-20{padding:20px}.p-24{padding:24px}.p-32{padding:32px}.p-40{padding:40px}.p-48{padding:48px}
.px-0{padding-left:0;padding-right:0}.px-8{padding-left:8px;padding-right:8px}.px-16{padding-left:16px;padding-right:16px}.px-24{padding-left:24px;padding-right:24px}.px-32{padding-left:32px;padding-right:32px}
.py-0{padding-top:0;padding-bottom:0}.py-8{padding-top:8px;padding-bottom:8px}.py-16{padding-top:16px;padding-bottom:16px}.py-24{padding-top:24px;padding-bottom:24px}.py-32{padding-top:32px;padding-bottom:32px}
.m-0{margin:0}.m-4{margin:4px}.m-8{margin:8px}.m-16{margin:16px}.m-24{margin:24px}.m-32{margin:32px}
.mx-0{margin-left:0;margin-right:0}.mx-8{margin-left:8px;margin-right:8px}.mx-16{margin-left:16px;margin-right:16px}
.my-0{margin-top:0;margin-bottom:0}.my-8{margin-top:8px;margin-bottom:8px}.my-16{margin-top:16px;margin-bottom:16px}

/* ===== FEATURE GRID ===== */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.feature-card{text-align:center;padding:40px 24px}
.feature-icon{width:64px;height:64px;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.03);border-radius:16px}
.feature-title{font-size:1.1rem;font-weight:700;margin-bottom:8px;color:#1A1A1A}
.feature-desc{font-size:.875rem;color:#1A1A1A;opacity:.5;line-height:1.8}
@media(max-width:768px){.feature-grid{grid-template-columns:1fr}}

/* ===== COMPARISON TABLE ===== */
.comparison{width:100%;border-collapse:collapse;margin:40px 0}
.comparison th{padding:16px;background:#B8956A;color:#fff;font-size:.85rem;font-weight:600;text-align:center}
.comparison td{padding:14px 16px;text-align:center;border-bottom:1px solid #E5E0DA;font-size:.9rem;color:#1A1A1A}
.comparison tr:hover td{background:rgba(0,0,0,.02)}
.comparison .plan-name{font-weight:700;font-size:1.1rem}
.comparison .check{color:#B8956A;font-weight:700}
.comparison .cross{color:#1A1A1A;opacity:.3}

/* ===== STEP INDICATOR ===== */
.step-indicator{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:48px}
.step-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;background:#E5E0DA;color:#1A1A1A;opacity:.5;transition:all .3s}
.step-dot.active{background:#B8956A;color:#fff;opacity:1}
.step-dot.completed{background:#B8956A;color:#fff;opacity:1}
.step-line{width:60px;height:2px;background:#E5E0DA;transition:background .3s}
.step-line.completed{background:#B8956A}

/* ===== GALLERY ===== */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.gallery-item{position:relative;overflow:hidden;border-radius:4px;cursor:pointer;aspect-ratio:1/1}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.gallery-item:hover img{transform:scale(1.1)}
.gallery-item::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,0);transition:background .3s}
.gallery-item:hover::after{background:rgba(0,0,0,.2)}
@media(max-width:768px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}

/* ===== PRICING TABLE ===== */
.pricing-table{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin:40px 0}
.pricing-card{background:#FEFEFE;border:1px solid #E5E0DA;border-radius:12px;padding:40px;text-align:center;transition:all .3s ease;position:relative}
.pricing-card.popular{border-color:#B8956A;transform:scale(1.02)}
.pricing-card.popular::before{content:'おすすめ';position:absolute;top:-12px;left:50%;transform:translateX(-50%);padding:4px 20px;background:#B8956A;color:#fff;font-size:.75rem;font-weight:700;border-radius:20px}
.pricing-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.08)}
.pricing-plan{font-size:1.1rem;font-weight:700;color:#1A1A1A;margin-bottom:12px}
.pricing-price{font-size:2.5rem;font-weight:800;color:#B8956A;margin-bottom:4px}
.pricing-period{font-size:.8rem;color:#1A1A1A;opacity:.4;margin-bottom:24px}
.pricing-features{text-align:left;margin-bottom:32px}
.pricing-features li{padding:8px 0;padding-left:24px;position:relative;font-size:.875rem;color:#1A1A1A;opacity:.7}
.pricing-features li::before{content:'';position:absolute;left:2px;top:14px;width:12px;height:6px;border-left:2px solid #B8956A;border-bottom:2px solid #B8956A;transform:rotate(-45deg)}
@media(max-width:768px){.pricing-table{grid-template-columns:1fr}.pricing-card.popular{transform:none}}

/* ===== MAP SECTION ===== */
.map-section{position:relative}
.map-container{width:100%;height:400px;background:#F7F5F2;border-radius:8px;overflow:hidden}
.map-container iframe{width:100%;height:100%;border:0}
.map-info{position:absolute;bottom:24px;left:24px;background:#FEFEFE;padding:24px;border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.1);max-width:320px}
.map-info h3{font-size:1rem;font-weight:700;margin-bottom:8px;color:#1A1A1A}
.map-info p{font-size:.85rem;color:#1A1A1A;opacity:.6;line-height:1.7}

/* ===== SIDEBAR ===== */
.layout-sidebar{display:grid;grid-template-columns:1fr 300px;gap:40px}
.sidebar{position:sticky;top:100px;align-self:start}
.sidebar-widget{background:#FEFEFE;border:1px solid #E5E0DA;border-radius:8px;padding:24px;margin-bottom:24px}
.sidebar-widget h3{font-size:1rem;font-weight:700;margin-bottom:16px;color:#1A1A1A}
.sidebar-list li{padding:8px 0;border-bottom:1px solid #E5E0DA;font-size:.875rem}
.sidebar-list li:last-child{border-bottom:none}
.sidebar-list a{color:#1A1A1A;opacity:.7;transition:all .2s}
.sidebar-list a:hover{color:#B8956A;opacity:1}
@media(max-width:1024px){.layout-sidebar{grid-template-columns:1fr}.sidebar{position:static}}

/* ===== CONTENT STYLES ===== */
.content h1{font-size:2rem;font-weight:800;margin-bottom:24px;color:#1A1A1A}
.content h2{font-size:1.5rem;font-weight:700;margin-top:40px;margin-bottom:16px;color:#1A1A1A}
.content h3{font-size:1.25rem;font-weight:600;margin-top:32px;margin-bottom:12px;color:#1A1A1A}
.content p{margin-bottom:16px;color:#1A1A1A;opacity:.7;line-height:2}
.content ul,.content ol{margin-bottom:16px;padding-left:24px}
.content li{margin-bottom:8px;color:#1A1A1A;opacity:.7}
.content blockquote{border-left:3px solid #B8956A;padding:16px 24px;margin:24px 0;background:#F7F5F2;border-radius:0 8px 8px 0}
.content blockquote p{margin-bottom:0;font-style:italic}
.content img{border-radius:8px;margin:24px 0}
.content a{color:#B8956A;text-decoration:underline}
.content a:hover{text-decoration:none}
.content table{width:100%;border-collapse:collapse;margin:24px 0}
.content table th,.content table td{padding:12px 16px;border:1px solid #E5E0DA;font-size:.9rem}
.content table th{background:#F7F5F2;font-weight:600}
.content code{background:#F7F5F2;padding:2px 8px;border-radius:4px;font-size:.85rem;font-family:monospace}
.content pre{background:#F7F5F2;padding:20px;border-radius:8px;overflow-x:auto;margin:24px 0}
.content pre code{background:none;padding:0}
.content hr{border:none;height:1px;background:#E5E0DA;margin:40px 0}

/* ===== SOCIAL LINKS ===== */
.social-links{display:flex;gap:12px}
.social-link{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:1px solid #E5E0DA;border-radius:50%;color:#1A1A1A;transition:all .3s}
.social-link:hover{background:#B8956A;border-color:#B8956A;color:#fff}
.social-link svg{width:18px;height:18px}

/* ===== PAGINATION ===== */
.pagination{display:flex;align-items:center;justify-content:center;gap:8px;margin:48px 0}
.page-link{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:1px solid #E5E0DA;border-radius:4px;font-size:.875rem;color:#1A1A1A;transition:all .2s}
.page-link:hover{border-color:#B8956A;color:#B8956A}
.page-link.active{background:#B8956A;border-color:#B8956A;color:#fff}
.page-dots{color:#1A1A1A;opacity:.3}

/* ===== DROPDOWN ===== */
.dropdown{position:relative;display:inline-block}
.dropdown-toggle{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#FEFEFE;border:1px solid #E5E0DA;border-radius:4px;cursor:pointer;font-size:.9rem}
.dropdown-menu{position:absolute;top:100%;left:0;min-width:200px;background:#FEFEFE;border:1px solid #E5E0DA;border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.1);opacity:0;transform:translateY(8px);pointer-events:none;transition:all .2s;z-index:100}
.dropdown.open .dropdown-menu{opacity:1;transform:translateY(4px);pointer-events:auto}
.dropdown-item{padding:10px 16px;font-size:.875rem;color:#1A1A1A;cursor:pointer;transition:background .2s}
.dropdown-item:hover{background:#F7F5F2}

/* ===== CHIP ===== */
.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;background:#F7F5F2;border:1px solid #E5E0DA;border-radius:20px;font-size:.8rem;color:#1A1A1A}
.chip-close{width:16px;height:16px;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.1);border-radius:50%;cursor:pointer;font-size:.7rem}
.chip-group{display:flex;flex-wrap:wrap;gap:8px}

/* ===== EMPTY STATE ===== */
.empty-state{text-align:center;padding:80px 24px}
.empty-state-icon{width:80px;height:80px;margin:0 auto 24px;opacity:.2}
.empty-state h3{font-size:1.25rem;font-weight:700;margin-bottom:8px;color:#1A1A1A}
.empty-state p{font-size:.95rem;color:#1A1A1A;opacity:.5;margin-bottom:24px}

/* ===== SKELETON LOADING ===== */
.skeleton-text{height:16px;background:#E5E0DA;border-radius:4px;margin-bottom:12px}
.skeleton-text.w-75{width:75%}
.skeleton-text.w-50{width:50%}
.skeleton-text.w-25{width:25%}
.skeleton-title{height:24px;width:60%;background:#E5E0DA;border-radius:4px;margin-bottom:16px}
.skeleton-image{width:100%;aspect-ratio:16/9;background:#E5E0DA;border-radius:8px}
.skeleton-avatar{width:48px;height:48px;border-radius:50%;background:#E5E0DA}
.skeleton-card{padding:24px;border:1px solid #E5E0DA;border-radius:8px}

/* ===== ACCESS MAP ===== */
.access-map{background:#F7F5F2}
.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.access-image{border-radius:8px;overflow:hidden}
.access-image img{width:100%;aspect-ratio:16/10;object-fit:cover}
.access-info{display:flex;flex-direction:column;gap:24px}
.access-item h3{font-size:1rem;font-weight:700;margin-bottom:8px;color:#1A1A1A}
.access-item p{font-size:.9rem;color:#1A1A1A;opacity:.6;line-height:1.8}
@media(max-width:768px){.access-grid{grid-template-columns:1fr}}

/* ===== COLUMN / BLOG ===== */
.column{background:#FEFEFE}
.column-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.column-card{background:#F7F5F2;border-radius:8px;overflow:hidden;border:1px solid #E5E0DA;transition:all .3s ease}
.column-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.06)}
.column-image{aspect-ratio:16/9;overflow:hidden}
.column-image img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.column-card:hover .column-image img{transform:scale(1.05)}
.column-body{padding:24px}
.column-date{font-size:.75rem;color:#B8956A;font-weight:600}
.column-title{font-size:1rem;font-weight:700;margin:8px 0;line-height:1.5;color:#1A1A1A}
.column-excerpt{font-size:.85rem;color:#1A1A1A;opacity:.55;line-height:1.8}
@media(max-width:768px){.column-grid{grid-template-columns:1fr}}

/* ===== CAROUSEL ===== */
.carousel{position:relative;overflow:hidden}
.carousel-track{display:flex;transition:transform .5s ease}
.carousel-slide{flex:0 0 100%;padding:0 12px}
.carousel-prev,.carousel-next{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;background:#FEFEFE;border:1px solid #E5E0DA;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;transition:all .2s}
.carousel-prev{left:12px}
.carousel-next{right:12px}
.carousel-prev:hover,.carousel-next:hover{background:#B8956A;border-color:#B8956A;color:#fff}
.carousel-dots{display:flex;justify-content:center;gap:8px;margin-top:24px}
.carousel-dot{width:8px;height:8px;border-radius:50%;background:#E5E0DA;cursor:pointer;transition:all .2s}
.carousel-dot.active{background:#B8956A;width:24px;border-radius:4px}

/* ===== TOOLTIP ENHANCED ===== */
.tooltip-top::after{bottom:calc(100% + 8px);top:auto}
.tooltip-bottom::after{top:calc(100% + 8px);bottom:auto}
.tooltip-left::after{right:calc(100% + 8px);left:auto;top:50%;bottom:auto;transform:translateY(-50%)}
.tooltip-right::after{left:calc(100% + 8px);right:auto;top:50%;bottom:auto;transform:translateY(-50%)}

/* ===== POPOVER ===== */
.popover{position:absolute;background:#FEFEFE;border:1px solid #E5E0DA;border-radius:8px;padding:16px;box-shadow:0 8px 24px rgba(0,0,0,.12);z-index:200;max-width:300px;opacity:0;pointer-events:none;transition:opacity .2s}
.popover.show{opacity:1;pointer-events:auto}
.popover-arrow{position:absolute;width:12px;height:12px;background:#FEFEFE;border:1px solid #E5E0DA;border-right:none;border-bottom:none;transform:rotate(45deg);top:-7px;left:24px}

/* ===== RIBBON ===== */
.ribbon{position:absolute;top:12px;right:-8px;padding:4px 16px;background:#B8956A;color:#fff;font-size:.75rem;font-weight:700;z-index:10}
.ribbon::after{content:'';position:absolute;right:0;bottom:-8px;border:4px solid transparent;border-top-color:#B8956A;border-right-color:#B8956A}

/* ===== FLOATING LABEL ===== */
.float-label{position:relative}
.float-label input,.float-label textarea{padding-top:24px}
.float-label label{position:absolute;top:18px;left:16px;font-size:.9rem;color:#1A1A1A;opacity:.4;transition:all .2s;pointer-events:none}
.float-label input:focus~label,.float-label input:not(:placeholder-shown)~label,.float-label textarea:focus~label,.float-label textarea:not(:placeholder-shown)~label{top:6px;font-size:.7rem;opacity:.6;color:#B8956A}

/* ===== COUNT BADGE ===== */
.count-badge{position:relative;display:inline-block}
.count-badge::after{content:attr(data-count);position:absolute;top:-8px;right:-8px;width:20px;height:20px;background:#B8956A;color:#fff;font-size:.65rem;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center}

/* ===== STATUS DOT ===== */
.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px}
.status-dot.online{background:#16A34A}
.status-dot.offline{background:#9CA3AF}
.status-dot.busy{background:#EAB308}
.status-dot.error{background:#DC2626}

/* ===== MASONRY ===== */
.masonry{columns:3;column-gap:24px}
.masonry-item{break-inside:avoid;margin-bottom:24px}
@media(max-width:768px){.masonry{columns:2}}
@media(max-width:480px){.masonry{columns:1}}

/* ===== ADDITIONAL RESPONSIVE HELPERS ===== */
.hide-mobile{display:block}
.show-mobile{display:none}
.hide-tablet{display:block}
.show-tablet{display:none}
@media(max-width:768px){
  .hide-mobile{display:none}
  .show-mobile{display:block}
}
@media(max-width:1024px){
  .hide-tablet{display:none}
  .show-tablet{display:block}
}

/* ===== ASPECT RATIOS ===== */
.aspect-1-1{aspect-ratio:1/1}
.aspect-4-3{aspect-ratio:4/3}
.aspect-3-2{aspect-ratio:3/2}
.aspect-16-9{aspect-ratio:16/9}
.aspect-21-9{aspect-ratio:21/9}

/* ===== Z-INDEX SYSTEM ===== */
.z-0{z-index:0}
.z-10{z-index:10}
.z-20{z-index:20}
.z-30{z-index:30}
.z-40{z-index:40}
.z-50{z-index:50}
.z-100{z-index:100}
.z-auto{z-index:auto}
.z-header{z-index:1000}
.z-modal{z-index:2000}
.z-tooltip{z-index:3000}
.z-notification{z-index:4000}

/* ===== OVERFLOW UTILITIES ===== */
.overflow-auto{overflow:auto}
.overflow-scroll{overflow:scroll}
.overflow-x-auto{overflow-x:auto}
.overflow-y-auto{overflow-y:auto}
.overflow-x-hidden{overflow-x:hidden}
.overflow-y-hidden{overflow-y:hidden}

/* ===== POSITION UTILITIES ===== */
.fixed{position:fixed}
.sticky{position:sticky}
.static{position:static}
.inset-0{top:0;right:0;bottom:0;left:0}
.top-0{top:0}
.right-0{right:0}
.bottom-0{bottom:0}
.left-0{left:0}

/* ===== BORDER UTILITIES ===== */
.border{border:1px solid currentColor}
.border-0{border:none}
.border-t{border-top:1px solid currentColor}
.border-b{border-bottom:1px solid currentColor}
.border-l{border-left:1px solid currentColor}
.border-r{border-right:1px solid currentColor}

/* ===== WIDTH & HEIGHT ===== */
.w-auto{width:auto}
.w-1-2{width:50%}
.w-1-3{width:33.333%}
.w-2-3{width:66.667%}
.w-1-4{width:25%}
.w-3-4{width:75%}
.w-screen{width:100vw}
.h-auto{height:auto}
.h-full{height:100%}
.h-screen{height:100vh}
.min-h-0{min-height:0}
.min-h-full{min-height:100%}
.min-h-screen{min-height:100vh}
.max-h-full{max-height:100%}
.max-h-screen{max-height:100vh}

/* ===== FLEX UTILITIES ===== */
.flex-1{flex:1}
.flex-auto{flex:auto}
.flex-none{flex:none}
.flex-grow{flex-grow:1}
.flex-grow-0{flex-grow:0}
.flex-shrink{flex-shrink:1}
.flex-shrink-0{flex-shrink:0}
.order-first{order:-1}
.order-last{order:999}
.order-none{order:0}
.self-auto{align-self:auto}
.self-start{align-self:flex-start}
.self-end{align-self:flex-end}
.self-center{align-self:center}
.self-stretch{align-self:stretch}
.items-start{align-items:flex-start}
.items-end{align-items:flex-end}
.items-baseline{align-items:baseline}
.items-stretch{align-items:stretch}
.justify-start{justify-content:flex-start}
.justify-end{justify-content:flex-end}
.justify-around{justify-content:space-around}
.justify-evenly{justify-content:space-evenly}
.content-start{align-content:flex-start}
.content-end{align-content:flex-end}
.content-center{align-content:center}

/* ===== TRANSFORM UTILITIES ===== */
.rotate-0{transform:rotate(0)}
.rotate-45{transform:rotate(45deg)}
.rotate-90{transform:rotate(90deg)}
.rotate-180{transform:rotate(180deg)}
.rotate-270{transform:rotate(270deg)}
.scale-90{transform:scale(.9)}
.scale-95{transform:scale(.95)}
.scale-100{transform:scale(1)}
.scale-105{transform:scale(1.05)}
.scale-110{transform:scale(1.1)}
.translate-x-0{transform:translateX(0)}
.translate-y-0{transform:translateY(0)}
.-translate-x-full{transform:translateX(-100%)}
.-translate-y-full{transform:translateY(-100%)}
.translate-x-full{transform:translateX(100%)}
.translate-y-full{transform:translateY(100%)}
.origin-center{transform-origin:center}
.origin-top{transform-origin:top}
.origin-bottom{transform-origin:bottom}

/* ===== FILTER UTILITIES ===== */
.blur-sm{filter:blur(4px)}
.blur{filter:blur(8px)}
.blur-md{filter:blur(12px)}
.blur-lg{filter:blur(16px)}
.blur-xl{filter:blur(24px)}
.brightness-50{filter:brightness(.5)}
.brightness-75{filter:brightness(.75)}
.brightness-100{filter:brightness(1)}
.brightness-125{filter:brightness(1.25)}
.contrast-50{filter:contrast(.5)}
.contrast-100{filter:contrast(1)}
.contrast-125{filter:contrast(1.25)}
.grayscale{filter:grayscale(100%)}
.grayscale-0{filter:grayscale(0)}
.saturate-50{filter:saturate(.5)}
.saturate-100{filter:saturate(1)}
.saturate-150{filter:saturate(1.5)}
.sepia{filter:sepia(100%)}
.sepia-0{filter:sepia(0)}

/* ===== MEDIA ===== */
.media-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.media-item{padding:32px;border-radius:8px;border:1px solid currentColor;transition:all .3s}
.media-item:hover{transform:translateY(-3px)}
.media-date{font-size:.75rem;font-weight:600;opacity:.5}
.media-item h3{font-size:1rem;font-weight:700;margin:8px 0;line-height:1.5}
.media-item p{font-size:.85rem;opacity:.55;line-height:1.8}
@media(max-width:768px){.media-grid{grid-template-columns:1fr}}
