/* ==========================================================
   tklaw.kr — Main Stylesheet v1.0
   Palette: #0F0F14 black / #B8860B gold / #D4AF37 light gold
   Font: Playfair Display(영문 헤드) + Noto Sans/Serif KR
   ========================================================== */

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  font-family:'Noto Sans KR','Apple SD Gothic Neo','Malgun Gothic',sans-serif;
  font-size:16px;line-height:1.7;color:#222;background:#fff;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  word-break:keep-all;
}
img,svg,video{max-width:100%;display:block;}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit;}
a{color:inherit;text-decoration:none;transition:color .2s;}
a:hover{color:#B8860B;}
ul,ol{list-style:none;}
input,textarea,select{font:inherit;color:inherit;}

:root{
  --black:#0F0F14;
  --black-2:#1a1a22;
  --gold:#B8860B;
  --gold-2:#D4AF37;
  --gold-soft:rgba(184,134,11,.1);
  --white:#ffffff;
  --gray-1:#F5F5F7;
  --gray-2:#e5e5ea;
  --gray-3:#999;
  --text:#222;
  --text-mute:#666;
  --radius:6px;
  --radius-lg:12px;
  --shadow:0 4px 24px rgba(0,0,0,.08);
  --shadow-lg:0 12px 48px rgba(0,0,0,.16);
  --container:1200px;
  --header-h:80px;
}

.serif{font-family:'Noto Serif KR','Playfair Display',serif;}
.en{font-family:'Playfair Display','Noto Serif KR',serif;}

/* ---------- Container ---------- */
.container,
.section__inner{
  max-width:var(--container);margin:0 auto;padding:0 24px;width:100%;
}

.section{padding:100px 0;position:relative;}
.section--dark{background:var(--black);color:#fff;}
.section--gray{background:var(--gray-1);}
.section--gold{
  background:linear-gradient(135deg,#B8860B 0%,#8a6608 100%);color:#fff;
}
.section__head{text-align:center;margin-bottom:60px;}
.section__eyebrow{
  font-family:'Playfair Display',serif;font-size:14px;letter-spacing:4px;
  color:var(--gold);text-transform:uppercase;margin-bottom:14px;display:inline-block;
}
.section__title{
  font-family:'Noto Serif KR',serif;font-weight:700;font-size:38px;line-height:1.3;
  margin-bottom:18px;
}
.section--dark .section__title{color:#fff;}
.section__title em{color:var(--gold);font-style:normal;}
.section__lead{font-size:17px;color:var(--text-mute);max-width:680px;margin:0 auto;}
.section--dark .section__lead{color:#aaa;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 32px;font-size:15px;font-weight:500;letter-spacing:.5px;
  border-radius:var(--radius);transition:all .25s;cursor:pointer;
  border:1px solid transparent;line-height:1;white-space:nowrap;
}
.btn-gold{background:var(--gold);color:#fff;}
.btn-gold:hover{background:var(--gold-2);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow);}
.btn-outline{border-color:#fff;color:#fff;background:transparent;}
.btn-outline:hover{background:#fff;color:var(--black);}
.btn-dark{background:var(--black);color:#fff;}
.btn-dark:hover{background:#000;color:var(--gold-2);}
.btn-lg{padding:18px 44px;font-size:16px;}

/* ---------- Top Banner ---------- */
.top-banner{
  background:var(--gold);color:#fff;height:36px;line-height:36px;
  display:flex;align-items:center;justify-content:center;font-size:14px;
  position:relative;padding:0 50px;
}
.top-banner a{color:#fff;font-weight:500;}
.top-banner__close{
  position:absolute;right:14px;top:50%;transform:translateY(-50%);
  color:#fff;font-size:14px;width:24px;height:24px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}
.top-banner__close:hover{background:rgba(0,0,0,.2);}

/* ---------- Header ---------- */
.header{
  position:sticky;top:0;left:0;right:0;z-index:100;
  background:rgba(15,15,20,.95);backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.header__inner{
  max-width:var(--container);margin:0 auto;padding:0 24px;
  height:var(--header-h);display:flex;align-items:center;gap:32px;
}
.header__logo{display:flex;align-items:center;line-height:1;color:#fff;}
.header__logo img{height:60px;width:auto;display:block;}
@media (max-width:480px){ .header__logo img{height:46px;} }

.header__nav{flex:1;}
.header__nav > ul{display:flex;gap:36px;justify-content:center;}
.header__nav a{color:#eee;font-size:15px;font-weight:500;padding:8px 0;display:inline-block;}
.header__nav a:hover{color:var(--gold-2);}
.header__nav .has-sub{position:relative;}
.header__nav .sub-menu{
  position:absolute;top:100%;left:50%;transform:translateX(-50%);
  background:rgba(15,15,20,.98);min-width:180px;padding:12px 0;border-radius:6px;
  opacity:0;visibility:hidden;transition:all .25s;border:1px solid rgba(255,255,255,.08);
  box-shadow:0 12px 32px rgba(0,0,0,.4);
}
.header__nav .has-sub:hover .sub-menu{opacity:1;visibility:visible;}
.header__nav .sub-menu li{display:block;}
.header__nav .sub-menu a{display:block;padding:10px 22px;font-size:14px;}

.header__cta{display:flex;align-items:center;gap:14px;}
.header__tel{color:var(--gold-2);font-weight:700;font-size:17px;letter-spacing:.5px;}
.header__tel:hover{color:#fff;}

.header__burger{display:none;width:30px;height:30px;flex-direction:column;justify-content:space-around;}
.header__burger span{display:block;width:100%;height:2px;background:#fff;}

/* Mobile menu drawer */
.mobile-menu{
  position:fixed;top:0;right:-100%;width:80%;max-width:340px;height:100vh;
  background:var(--black);z-index:200;padding:80px 30px 30px;
  transition:right .35s;overflow-y:auto;
}
.mobile-menu.open{right:0;}
.mobile-menu ul li{border-bottom:1px solid rgba(255,255,255,.08);}
.mobile-menu ul li a{display:block;padding:18px 0;color:#eee;font-size:16px;}
.mobile-menu ul li a:hover{color:var(--gold);}
.mobile-menu__close{position:absolute;top:24px;right:24px;color:#fff;font-size:22px;}
.mobile-menu__cta{margin-top:30px;}
.mobile-menu__cta .btn{width:100%;margin-top:10px;}
.menu-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:150;
  opacity:0;visibility:hidden;transition:all .3s;
}
.menu-overlay.open{opacity:1;visibility:visible;}

/* ---------- Hero ---------- */
.hero{
  position:relative;height:100vh;min-height:600px;color:#fff;overflow:hidden;
  background:#000;
}
.hero__slide{
  position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;transition:opacity 1.2s;
}
.hero__slide.active{opacity:1;}
/* 오버레이는 index.php 에서 inline linear-gradient 로 제어 (관리자 설정 반영) */
.hero__inner{
  position:relative;z-index:2;height:100%;
  display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;
  max-width:var(--container);margin:0 auto;padding:0 24px;
}
.hero__sub{
  font-family:'Playfair Display',serif;font-size:14px;letter-spacing:6px;
  color:var(--gold-2);margin-bottom:24px;text-transform:uppercase;
}
.hero__title{
  font-family:'Noto Serif KR',serif;font-weight:700;
  font-size:clamp(32px,5vw,60px);line-height:1.25;margin-bottom:24px;
}
.hero__title em{color:var(--gold-2);font-style:normal;}
.hero__desc{font-size:18px;color:#ddd;margin-bottom:48px;max-width:640px;}
.hero__cta{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;}
.hero__scroll{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;
  color:#fff;font-size:24px;animation:bounce 2s infinite;
}
@keyframes bounce{
  0%,100%{transform:translateX(-50%) translateY(0);}
  50%{transform:translateX(-50%) translateY(-10px);}
}

/* ---------- Features (4 box) ---------- */
.features{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.feature{
  background:#fff;padding:48px 28px;border-radius:var(--radius-lg);
  text-align:center;transition:all .3s;border:1px solid var(--gray-2);
}
.feature:hover{transform:translateY(-6px);border-color:var(--gold);box-shadow:var(--shadow-lg);}
.feature__icon{font-size:42px;margin-bottom:18px;color:var(--gold);}
.feature__title{font-size:18px;font-weight:700;margin-bottom:12px;}
.feature__desc{font-size:14px;color:var(--text-mute);}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.stat{text-align:center;padding:30px 0;}
.stat__num{
  font-family:'Playfair Display',serif;font-size:54px;font-weight:700;
  color:var(--gold-2);line-height:1;margin-bottom:12px;
}
.stat__num small{font-size:24px;color:var(--gold);}
.stat__label{color:#ccc;font-size:14px;letter-spacing:.5px;}

/* ---------- About lawyer ---------- */
.about{display:grid;grid-template-columns:1fr 1.4fr;gap:60px;align-items:center;}
.about__photo{
  background:#eee;aspect-ratio:3/4;border-radius:var(--radius-lg);overflow:hidden;
  border:6px solid var(--gold-soft);
}
.about__photo img{width:100%;height:100%;object-fit:cover;}
.about__name{font-size:30px;font-weight:700;margin-bottom:8px;font-family:'Noto Serif KR',serif;}
.about__name small{font-size:16px;color:var(--gold);margin-left:10px;}
.about__reg{font-size:14px;color:var(--text-mute);margin-bottom:24px;}
.about__bio{font-size:15px;color:#444;margin-bottom:24px;line-height:1.9;}
.about__tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:30px;}
.tag{background:var(--gold-soft);color:var(--gold);padding:6px 14px;border-radius:20px;font-size:13px;}
.about__quote{
  border-left:3px solid var(--gold);padding:14px 22px;
  font-family:'Noto Serif KR',serif;font-size:18px;color:var(--black);font-style:italic;
}

/* ---------- Service grid ---------- */
.services{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;}
.service-card{
  background:#fff;padding:36px 22px;border-radius:var(--radius-lg);text-align:center;
  border:1px solid var(--gray-2);transition:all .3s;cursor:pointer;
}
.service-card:hover{
  background:var(--black);color:#fff;border-color:var(--gold);transform:translateY(-4px);
}
.service-card:hover .service-card__icon{color:var(--gold-2);}
.service-card__icon{font-size:36px;color:var(--gold);margin-bottom:18px;}
.service-card__title{font-size:18px;font-weight:700;margin-bottom:10px;}
.service-card__desc{font-size:13px;color:var(--text-mute);min-height:50px;}
.service-card:hover .service-card__desc{color:#bbb;}
.service-card__more{margin-top:14px;font-size:13px;color:var(--gold);}

/* ---------- Cases slider ---------- */
.cases-tabs{display:flex;justify-content:center;gap:8px;margin-bottom:36px;flex-wrap:wrap;}
.cases-tab{
  padding:10px 24px;background:#fff;border:1px solid var(--gray-2);
  border-radius:30px;cursor:pointer;font-size:14px;
}
.cases-tab.active{background:var(--black);color:#fff;border-color:var(--black);}
.cases-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.case-card{
  background:#fff;padding:30px;border-radius:var(--radius-lg);box-shadow:var(--shadow);
  border-top:3px solid var(--gold);
}
.case-card__cat{display:inline-block;font-size:12px;color:var(--gold);font-weight:700;margin-bottom:14px;letter-spacing:1px;}
.case-card__client{font-size:14px;color:var(--text-mute);margin-bottom:6px;}
.case-card__title{font-size:18px;font-weight:700;margin-bottom:18px;line-height:1.5;}
.case-card__data{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:18px 0;border-top:1px solid var(--gray-2);border-bottom:1px solid var(--gray-2);margin-bottom:18px;}
.case-card__data div{text-align:center;}
.case-card__data .label{font-size:12px;color:var(--text-mute);margin-bottom:4px;}
.case-card__data .value{font-weight:700;font-size:17px;color:var(--black);}
.case-card__rate{color:var(--gold) !important;}
.case-card__sum{font-size:14px;color:#555;line-height:1.7;}

/* ---------- 1분진단 ---------- */
.diagnosis{
  background:linear-gradient(135deg,#B8860B 0%,#8a6608 100%);color:#fff;
}
.diagnosis__box{
  max-width:780px;margin:0 auto;background:rgba(15,15,20,.85);
  padding:50px;border-radius:var(--radius-lg);
}
.diagnosis__form{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.diagnosis__field{margin-bottom:0;}
.diagnosis__field label{display:block;font-size:14px;color:var(--gold-2);margin-bottom:8px;}
.diagnosis__field input{
  width:100%;padding:14px 18px;background:#fff;border:none;border-radius:var(--radius);
  font-size:16px;color:var(--black);
}
.diagnosis__submit{grid-column:1/-1;margin-top:10px;}
.diagnosis__submit .btn{width:100%;padding:18px;font-size:16px;}
.diagnosis__result{
  margin-top:30px;padding:30px;background:rgba(212,175,55,.1);border:1px solid var(--gold-2);
  border-radius:var(--radius);display:none;
}
.diagnosis__result.show{display:block;}
.diagnosis__result h3{color:var(--gold-2);margin-bottom:18px;font-size:20px;}
.diagnosis__result ul li{padding:6px 0;font-size:15px;}
.diagnosis__result ul li strong{color:var(--gold-2);margin-right:10px;}
.diagnosis__note{font-size:12px;color:#aaa;margin-top:14px;}

/* ---------- Reviews (자필후기) ---------- */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.review-card{
  background:#fffdf7;padding:30px;border-radius:var(--radius-lg);
  box-shadow:var(--shadow);position:relative;
  background-image:linear-gradient(transparent 31px,rgba(0,0,0,.04) 32px);
  background-size:100% 32px;
}
.review-card::before{content:'"';position:absolute;top:10px;left:18px;font-size:60px;color:var(--gold);font-family:Georgia,serif;line-height:1;opacity:.4;}
.review-card__content{font-family:'Noto Serif KR',serif;font-size:15px;color:#333;line-height:2;margin:18px 0;min-height:120px;}
.review-card__author{font-size:13px;color:var(--text-mute);text-align:right;}
.review-card__author strong{color:var(--black);}
.review-card__rating{color:var(--gold);font-size:14px;margin-bottom:8px;}

/* ---------- Contact form ---------- */
.contact-form{max-width:780px;margin:0 auto;background:rgba(255,255,255,.04);padding:50px;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.08);}
.contact-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;}
.contact-form .form-field{margin-bottom:20px;}
.contact-form label{display:block;font-size:13px;color:var(--gold-2);margin-bottom:8px;letter-spacing:.5px;}
.contact-form label .req{color:#ff6b6b;margin-left:4px;}
.contact-form input,
.contact-form select,
.contact-form textarea{
  width:100%;padding:14px 16px;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);
  color:#fff;font-size:15px;
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{outline:none;border-color:var(--gold);background:rgba(255,255,255,.12);}
.contact-form select{
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%23D4AF37' d='M6 8L0 0h12z'/></svg>");
  background-repeat:no-repeat;background-position:right 16px center;padding-right:40px;
}
/* 드롭다운 옵션 가독성 — 다크 배경과 대비 */
.contact-form select option,
.contact-form select optgroup{
  background:#1a1a22;color:#fff;
}
.contact-form select option:checked,
.contact-form select option:hover{
  background:var(--gold);color:#fff;
}
.contact-form textarea{resize:vertical;min-height:120px;}
.contact-form .form-agree{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:#bbb;margin:24px 0;}
.contact-form .form-agree input{width:auto;}
.contact-form .form-submit{text-align:center;}
.contact-form .form-submit .btn{padding:18px 60px;font-size:16px;}

/* ---------- Map / Location ---------- */
.location{display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:start;}
.location__map{aspect-ratio:4/3;background:var(--gray-2);border-radius:var(--radius-lg);overflow:hidden;}
.location__info{padding:10px 0;}
.location__row{display:flex;gap:18px;padding:18px 0;border-bottom:1px solid var(--gray-2);}
.location__row .icon{font-size:24px;color:var(--gold);width:40px;flex-shrink:0;}
.location__row .label{font-size:13px;color:var(--text-mute);margin-bottom:2px;}
.location__row .value{font-weight:700;font-size:16px;}

/* ---------- Floating CTA ---------- */
.floating{
  position:fixed;right:20px;bottom:24px;z-index:90;
  display:flex;flex-direction:column;gap:10px;
  opacity:0;visibility:hidden;transition:all .3s;
}
.floating.show{opacity:1;visibility:visible;}
.floating__btn{
  width:54px;height:54px;border-radius:50%;background:var(--black);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:22px;
  box-shadow:0 6px 20px rgba(0,0,0,.25);transition:all .25s;
}
.floating__btn:hover{background:var(--gold);transform:translateY(-3px);color:#fff;}

/* ---------- Footer ---------- */
.footer{background:var(--black);color:#bbb;padding:60px 0 30px;}
.footer__inner{max-width:var(--container);margin:0 auto;padding:0 24px;}
.footer__brand{margin-bottom:30px;display:flex;flex-direction:column;line-height:1.2;}
.footer__brand .logo-en{font-family:'Playfair Display',serif;font-size:28px;color:var(--gold);font-weight:700;}
.footer__brand .logo-ko{font-size:13px;color:#888;margin-top:4px;}
.footer__info p{font-size:14px;line-height:2;color:#aaa;}
.footer__info a{color:var(--gold-2);}
.footer__info strong{color:#fff;}
.footer__links{margin:24px 0;display:flex;gap:24px;flex-wrap:wrap;}
.footer__links a{color:#bbb;font-size:13px;}
.footer__links a:hover{color:var(--gold);}
.footer__copy{padding-top:24px;border-top:1px solid rgba(255,255,255,.08);font-size:12px;color:#666;}

/* ---------- Error pages ---------- */
.error-page{padding:120px 0;text-align:center;}
.error-page__inner{max-width:520px;margin:0 auto;padding:0 24px;}
.error-code{font-family:'Playfair Display',serif;font-size:120px;font-weight:700;color:var(--gold);line-height:1;margin-bottom:20px;}
.error-page h1{font-size:24px;margin-bottom:14px;font-family:'Noto Serif KR',serif;}
.error-page p{color:var(--text-mute);margin-bottom:36px;}
.error-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}

/* ---------- Page Hero (sub pages) ---------- */
.page-hero{
  background:var(--black);color:#fff;padding:100px 0 80px;text-align:center;position:relative;
  background-image:linear-gradient(rgba(15,15,20,.85),rgba(15,15,20,.85));
  background-size:cover;background-position:center;
}
.page-hero h1{font-family:'Noto Serif KR',serif;font-size:42px;margin-bottom:16px;}
.page-hero p{color:#bbb;font-size:16px;}
.breadcrumb{display:flex;justify-content:center;gap:8px;font-size:13px;color:#888;margin-top:18px;}
.breadcrumb a{color:#aaa;}
.breadcrumb a:hover{color:var(--gold);}

/* ---------- Toast / Alert ---------- */
.toast{
  position:fixed;top:30px;left:50%;transform:translateX(-50%) translateY(-100px);
  background:var(--black);color:#fff;padding:14px 28px;border-radius:var(--radius);
  z-index:1000;box-shadow:var(--shadow-lg);transition:transform .35s;
}
.toast.show{transform:translateX(-50%) translateY(0);}
.toast--success{border-left:4px solid #4caf50;}
.toast--error{border-left:4px solid #f44336;}

/* ---------- Modal ---------- */
.modal{
  position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:300;
  display:none;align-items:center;justify-content:center;padding:24px;
}
.modal.open{display:flex;}
.modal__box{
  background:#fff;padding:40px;border-radius:var(--radius-lg);max-width:480px;
  width:100%;text-align:center;
}
.modal__icon{font-size:48px;color:var(--gold);margin-bottom:16px;}
.modal__title{font-size:22px;font-weight:700;margin-bottom:12px;}
.modal__desc{color:var(--text-mute);margin-bottom:30px;}

/* ---------- Responsive ---------- */
@media (max-width: 1024px){
  .features,.services,.cases-grid,.reviews,.stats{grid-template-columns:repeat(2,1fr);}
  .about,.location{grid-template-columns:1fr;}
  .section__title{font-size:30px;}
}
@media (max-width: 768px){
  .section{padding:70px 0;}
  .section__title{font-size:26px;}
  .header__nav,.header__cta .btn{display:none;}
  .header__burger{display:flex;}
  .header__cta{margin-left:auto;}
  .features,.services,.cases-grid,.reviews,.stats{grid-template-columns:1fr;}
  .stats{grid-template-columns:repeat(2,1fr);gap:14px;}
  .stat__num{font-size:40px;}
  .diagnosis__form,.contact-form .form-row{grid-template-columns:1fr;}
  .diagnosis__box,.contact-form{padding:30px 22px;}
  .hero__title{font-size:28px;}
  .hero__desc{font-size:15px;}
  .hero{min-height:520px;}
  .top-banner{font-size:12px;padding:0 36px;}
}
@media (max-width: 480px){
  .container,.section__inner,.header__inner,.footer__inner{padding:0 16px;}
  .btn{padding:12px 24px;font-size:14px;}
  .floating__btn{width:48px;height:48px;font-size:18px;}
}
