/* ===== 공통 스타일 (양육비 계산기 사이트 / teal) ===== */
:root{
  --bg:#eef4f2; --card:#ffffff; --ink:#10302c; --ink-2:#37514c;
  --muted:#62807a; --accent:#0f766e; --accent-2:#0d9488; --line:#d9e7e3;
  --good:#0f766e; --warn:#b45309; --soft:#f3f8f6;
  --shadow:0 1px 2px rgba(16,48,44,.04), 0 12px 30px rgba(16,48,44,.08);
  --ease:cubic-bezier(.16,1,.3,1);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; color:var(--ink);
  font-family:'Gothic A1',-apple-system,BlinkMacSystemFont,"Apple SD Gothic Neo",sans-serif;
  font-size:17px; line-height:1.7; word-break:keep-all; overflow-wrap:break-word;
  background:radial-gradient(120% 80% at 50% -10%, #f5faf8 0%, var(--bg) 55%) fixed;
}
.wrap{max-width:720px; margin:0 auto; padding:34px 20px 80px}
a{color:var(--accent)}

.back{display:inline-flex; align-items:center; gap:6px; color:var(--muted); text-decoration:none;
  font-weight:700; font-size:.92rem; margin-bottom:18px}
.back:hover{color:var(--accent)}

header{text-align:center; margin-bottom:20px; animation:rise .7s ease both}
.eyebrow{font-size:.78rem; letter-spacing:.2em; color:var(--accent); font-weight:700; margin-bottom:12px}
header h1{font-weight:800; font-size:2.05rem; margin:.1em 0 .35em; letter-spacing:-.02em; line-height:1.25}
header p{color:var(--ink-2); margin:0 auto; font-size:1.0rem; white-space:nowrap}
.rule{width:44px; height:3px; background:var(--accent); border-radius:3px; margin:18px auto 0}

.note{background:#e3f0ec; border:1px solid var(--line); border-radius:12px; padding:15px 18px;
  margin:18px 0 0; font-size:.93rem; color:var(--ink-2); line-height:1.65; text-align:justify;
  animation:rise .7s ease both .05s}
.note b{color:var(--accent); font-weight:700}
.lead{background:var(--soft); border:1px solid var(--line); border-radius:12px; padding:16px 18px;
  font-size:.97rem; color:var(--ink-2); line-height:1.65; text-align:justify}

.card{background:var(--card); border:1px solid var(--line); border-radius:14px; padding:28px 26px;
  margin:18px 0; box-shadow:var(--shadow); animation:rise .7s ease both .08s}
.card-title{font-weight:800; font-size:1.28rem; margin:0 0 6px; display:flex; align-items:baseline; gap:9px}
.card-title .no{color:var(--accent); font-size:.95rem}
.card-sub{color:var(--muted); font-size:.95rem; margin:0 0 4px}

label{display:block; font-size:1rem; color:var(--ink); margin:20px 0 4px; font-weight:700}
.qhint{font-size:.88rem; color:var(--muted); margin:0 0 9px; font-weight:400; line-height:1.55}

input[type=number], input[type=text], input[type=date], select{
  width:100%; padding:14px 16px; background:var(--soft); border:1px solid var(--line);
  border-radius:9px; color:var(--ink); font-size:1.08rem; font-family:inherit; outline:none;
  transition:border-color .15s, box-shadow .15s; font-variant-numeric:tabular-nums}
input:focus, select:focus{border-color:var(--accent); box-shadow:0 0 0 3px rgba(15,118,110,.14)}

.money-field{display:flex; align-items:center; background:var(--soft); border:1px solid var(--line);
  border-radius:9px; overflow:hidden; transition:border-color .15s, box-shadow .15s}
.money-field:focus-within{border-color:var(--accent); box-shadow:0 0 0 3px rgba(15,118,110,.14)}
.money-field input{flex:1; min-width:0; border:0; background:transparent; outline:none; box-shadow:none;
  padding:13px 6px 13px 14px; font-size:1.05rem; color:var(--ink); font-family:inherit;
  text-align:right; font-variant-numeric:tabular-nums}
.money-field .unit{padding:0 14px 0 6px; color:var(--muted); font-size:.95rem; white-space:nowrap}

.row{display:flex; gap:14px; flex-wrap:wrap}
.row > div{flex:1; min-width:150px}

/* 세그먼트 선택 / 토글 */
.seg{display:flex; gap:8px; margin-top:6px; flex-wrap:wrap}
.seg button{flex:1; min-width:90px; padding:12px 10px; border:1px solid var(--line); background:var(--soft);
  color:var(--muted); border-radius:9px; cursor:pointer; font-size:.98rem; font-weight:600;
  font-family:inherit; transition:all .15s; white-space:normal; word-break:keep-all; line-height:1.3}
.seg button:hover{border-color:var(--accent-2)}
.seg button.on{background:var(--accent); border-color:var(--accent); color:#fff}
.seg.tags button{flex:0 0 auto; min-width:0}  /* 항목이 많은 다중선택: 내용 크기 태그형 */

.calc-btn{width:100%; margin-top:24px; padding:17px; border:0; border-radius:10px;
  background:var(--accent); color:#fff; font-size:1.1rem; font-weight:800; font-family:inherit;
  cursor:pointer; transition:transform .12s, background .2s; box-shadow:0 8px 20px rgba(15,118,110,.22)}
.calc-btn:hover{background:#0c5d57}
.calc-btn:active{transform:translateY(1px)}
.reset-btn{width:100%; margin-top:10px; padding:13px; border:1px solid var(--line); border-radius:10px;
  background:transparent; color:var(--muted); font-size:1rem; font-weight:700; font-family:inherit;
  cursor:pointer; transition:border-color .15s, color .15s}
.reset-btn:hover{border-color:var(--accent); color:var(--accent)}
.linkbtn{background:none; border:0; color:var(--accent); font-weight:700; cursor:pointer;
  font-family:inherit; font-size:1rem; padding:0; margin-top:16px; text-decoration:underline}
.linkbtn:hover{color:var(--ink)}
.err{color:var(--warn); font-size:.92rem; margin-top:14px; display:none; line-height:1.5}

/* 결과 */
.result{display:none}
.result.shown{animation:rise .6s var(--ease) both}
.sum{font-size:.92rem; color:var(--muted); line-height:1.6}
.table-wrap{overflow-x:auto; -webkit-overflow-scrolling:touch}
table{width:100%; border-collapse:collapse; margin-top:10px; font-size:1.0rem}
th,td{text-align:right; padding:13px 8px; border-bottom:1px solid var(--line)}
thead th{color:var(--accent); font-weight:700; font-size:.82rem; letter-spacing:.02em; border-bottom:1.5px solid var(--accent-2)}
td:first-child, th:first-child{text-align:left}
tbody tr:last-child td{border-bottom:0}
.who{font-weight:700; color:var(--ink)}
.amt{font-variant-numeric:tabular-nums}
.pill{display:inline-block; font-size:.82rem; padding:3px 10px; border-radius:6px;
  background:rgba(15,118,110,.1); color:var(--accent); font-weight:700}

.stat{display:flex; justify-content:space-between; align-items:center; margin-top:14px;
  padding:14px 18px; background:var(--soft); border:1px solid var(--line); border-radius:10px}
.stat .k{color:var(--muted); font-size:.95rem; font-weight:600}
.stat .v{font-size:1.15rem; font-weight:800; color:var(--ink); font-variant-numeric:tabular-nums}
.big{margin-top:14px; padding:22px 20px; border-radius:12px; text-align:center;
  background:linear-gradient(135deg, #0f766e, #0d9488); color:#fff}
.big .k{font-size:.95rem; opacity:.92; font-weight:600}
.big .v{font-size:1.85rem; font-weight:800; margin-top:6px; font-variant-numeric:tabular-nums; line-height:1.2}
.big .vsub{font-size:.9rem; opacity:.9; margin-top:6px}

.disc{font-size:.86rem; color:var(--muted); margin-top:20px; padding:16px 18px;
  background:rgba(255,255,255,.6); border:1px solid var(--line); border-radius:10px; line-height:1.6; text-align:justify}

/* 탭 */
.tabs{display:flex; gap:6px; background:#e1ebe8; padding:6px; border-radius:13px; margin:18px 0;
  animation:rise .7s ease both .06s}
.tabs button{flex:1; padding:14px 10px; border:0; border-radius:9px; background:transparent;
  color:var(--muted); font-weight:700; font-size:1.02rem; font-family:inherit; cursor:pointer;
  transition:all .22s; line-height:1.3}
.tabs button .tsub{display:block; font-size:.74rem; font-weight:500; opacity:.8; margin-top:2px}
.tabs button.active{background:var(--card); color:var(--ink); box-shadow:var(--shadow)}
.panel{display:none}
.panel.active{display:block; animation:rise .5s var(--ease) both}

/* 설명보기 정보 버튼 + 모달 */
.info-btn{display:inline-flex; align-items:center; justify-content:center; width:18px; height:18px;
  border-radius:50%; background:var(--accent); color:#fff; font-size:.72rem; font-weight:800;
  border:0; cursor:pointer; margin-left:6px; vertical-align:middle; line-height:1; flex:0 0 auto}
.info-btn:hover{background:var(--accent-2)}
.modal-backdrop{display:none; position:fixed; inset:0; background:rgba(16,48,44,.42);
  -webkit-backdrop-filter:blur(3px); backdrop-filter:blur(3px);
  z-index:50; align-items:center; justify-content:center; padding:20px; animation:fade .28s ease both}
.modal-backdrop.open{display:flex}
.modal-box{background:var(--card); border-radius:16px; max-width:440px; width:100%; padding:26px 24px;
  box-shadow:0 24px 70px rgba(16,48,44,.32); animation:pop .36s var(--ease) both; max-height:80vh; overflow-y:auto}
.modal-box h3{margin:0 0 10px; font-size:1.2rem; font-weight:800}
.modal-box p{margin:0 0 10px; color:var(--ink-2); font-size:.97rem; line-height:1.7; text-align:justify}
.modal-box .close{margin-top:16px; width:100%; padding:13px; border:0; border-radius:9px;
  background:var(--soft); color:var(--ink); font-weight:700; font-family:inherit; cursor:pointer; font-size:1rem}
.modal-box .close:hover{background:#e6efec}

/* FAQ 아코디언 */
.acc{margin-top:6px}
.acc-item{border-bottom:1px solid var(--line)}
.acc-item:first-child{border-top:1px solid var(--line)}
.acc-q{width:100%; text-align:left; background:none; border:0; cursor:pointer; font-size:1.08rem;
  font-weight:700; color:var(--ink); font-family:inherit; padding:18px 40px 18px 2px; position:relative; line-height:1.5}
.acc-q:hover{color:var(--accent)}
.acc-q::after{content:""; position:absolute; right:6px; top:50%; width:15px; height:15px; transform:translateY(-50%);
  background:
    linear-gradient(var(--accent),var(--accent)) center/100% 2px no-repeat,
    linear-gradient(var(--accent),var(--accent)) center/2px 100% no-repeat;
  transition:transform .4s var(--ease)}
.acc-item.open .acc-q::after{transform:translateY(-50%) rotate(45deg)}
.acc-a{max-height:0; overflow:hidden; transition:max-height .42s var(--ease)}
.acc-item.open .acc-a{max-height:600px}
.acc-a p{margin:0 2px 18px; color:var(--ink-2); line-height:1.75; text-align:justify; font-size:1rem}

footer.site{text-align:center; margin-top:26px; padding-top:18px; border-top:1px solid var(--line);
  color:var(--muted); font-size:.88rem}
footer.site a{color:var(--accent); text-decoration:none; font-weight:700}

/* 공유하기 */
.share-wrap{text-align:center; margin-top:20px}
.share-btn{display:inline-flex; align-items:center; gap:8px; background:#e3f0ec; color:var(--accent);
  border:1px solid var(--line); border-radius:999px; padding:12px 22px; font-weight:700; font-size:.98rem;
  font-family:inherit; cursor:pointer; transition:background .15s, transform .12s}
.share-btn:hover{background:#d5e8e2} .share-btn:active{transform:translateY(1px)}
.share-btn svg{width:18px; height:18px}
.toast{position:fixed; left:50%; bottom:32px; transform:translateX(-50%) translateY(20px); opacity:0;
  background:var(--ink); color:#fff; padding:13px 22px; border-radius:10px; font-size:.95rem; font-weight:600;
  z-index:80; transition:opacity .25s, transform .25s; pointer-events:none; box-shadow:0 10px 30px rgba(16,48,44,.3)}
.toast.show{opacity:1; transform:translateX(-50%) translateY(0)}

/* 양육비: 자녀 입력 행 / 가감 */
.child{display:flex; gap:10px; align-items:center; margin-top:10px}
.child input{flex:1}
.child .rm{padding:13px 16px; background:var(--soft); border:1px solid var(--line); color:var(--muted);
  border-radius:9px; cursor:pointer; font-family:inherit; font-size:.95rem; white-space:nowrap}
.child .rm:hover{color:var(--warn); border-color:#e7c9a8}
.addBtn{margin-top:12px; width:100%; padding:12px; border:1px dashed #b9d2cc; background:transparent;
  color:var(--accent); border-radius:9px; cursor:pointer; font-weight:700; font-family:inherit; font-size:.98rem}
.addBtn:hover{background:#f0f7f5}
details.adj{margin-top:18px; border-top:1px solid var(--line); padding-top:8px}
details.adj summary{cursor:pointer; color:var(--accent); font-size:.95rem; font-weight:600; padding:8px 0}

/* ===== 홈·카테고리 네비게이션 (index + 카테고리 페이지 공용) ===== */
.cat{margin-top:30px; animation:rise .6s var(--ease) both}
.cat-head{display:flex; align-items:center; gap:10px; margin:0 0 14px; padding:0 2px}
.cat-dot{flex:0 0 auto; width:10px; height:10px; border-radius:50%; background:var(--accent);
  box-shadow:0 0 0 4px rgba(15,118,110,.15); animation:catpulse 2.6s ease-in-out infinite}
.cat-title{font-size:1.06rem; font-weight:800; color:var(--ink); letter-spacing:-.01em; white-space:nowrap}
.cat-line{flex:1; height:1px; background:linear-gradient(to right, var(--line), transparent)}
@keyframes catpulse{0%,100%{box-shadow:0 0 0 4px rgba(15,118,110,.16)} 50%{box-shadow:0 0 0 8px rgba(15,118,110,.04)}}

.grid{display:flex; flex-direction:column; gap:14px}
.ccard{display:flex; align-items:center; gap:18px; text-decoration:none; color:inherit;
  background:var(--card); border:1px solid var(--line); border-radius:16px; padding:20px 22px;
  box-shadow:var(--shadow); transition:transform .2s var(--ease), box-shadow .2s var(--ease), border-color .2s;
  position:relative; overflow:hidden; animation:rise .55s var(--ease) both}
.grid .ccard:nth-child(1){animation-delay:.04s} .grid .ccard:nth-child(2){animation-delay:.1s} .grid .ccard:nth-child(3){animation-delay:.16s}
.ccard::after{content:""; position:absolute; inset:0; border-radius:16px; pointer-events:none;
  background:radial-gradient(120% 140% at 0% 50%, rgba(15,118,110,.07), transparent 60%); opacity:0; transition:opacity .25s ease}
.ccard::before{content:""; position:absolute; left:0; top:0; width:4px; height:100%; background:var(--accent); opacity:0; transition:opacity .2s}
.ccard:hover{transform:translateY(-3px); box-shadow:0 16px 38px rgba(15,118,110,.16); border-color:var(--accent-2)}
.ccard:hover::before{opacity:1} .ccard:hover::after{opacity:1}
.ico{flex:0 0 auto; width:52px; height:52px; border-radius:14px; background:#e3f0ec;
  display:flex; align-items:center; justify-content:center; color:var(--accent); transition:transform .25s var(--ease)}
.ccard:hover .ico{transform:scale(1.08) rotate(-3deg)}
.ico svg{width:28px; height:28px}
.ctxt{flex:1; min-width:0}
.ctxt .t{display:block; font-size:1.2rem; font-weight:800; letter-spacing:-.01em}
.ctxt .d{display:block; color:var(--muted); font-size:.92rem; margin-top:4px; line-height:1.5}
.arrow{flex:0 0 auto; color:var(--accent); font-size:1.4rem; font-weight:700; transition:transform .2s var(--ease)}
.ccard:hover .arrow{transform:translateX(4px)}

/* 홈 대분류 버튼 */
.cathub{display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:30px}
.cathub > .catbtn:last-child:nth-child(odd){grid-column:1 / -1}
.catbtn{display:flex; flex-direction:column; text-decoration:none; color:inherit;
  background:var(--card); border:1px solid var(--line); border-radius:18px; padding:24px 22px 22px;
  box-shadow:var(--shadow); position:relative; overflow:hidden;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease), border-color .2s;
  animation:rise .55s var(--ease) both}
.cathub .catbtn:nth-child(1){animation-delay:.04s} .cathub .catbtn:nth-child(2){animation-delay:.1s}
.cathub .catbtn:nth-child(3){animation-delay:.16s} .cathub .catbtn:nth-child(4){animation-delay:.22s}
.catbtn::after{content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(120% 120% at 100% 0%, rgba(15,118,110,.08), transparent 55%); opacity:0; transition:opacity .25s}
.catbtn:hover{transform:translateY(-4px); box-shadow:0 18px 40px rgba(15,118,110,.16); border-color:var(--accent-2)}
.catbtn:hover::after{opacity:1}
.catbtn .ico{width:54px; height:54px; margin-bottom:14px}
.catbtn:hover .ico{transform:scale(1.08) rotate(-3deg)}
.catbtn .ct{font-size:1.28rem; font-weight:800; letter-spacing:-.01em; display:flex; align-items:center; gap:8px}
.catbtn .ct .go{color:var(--accent); font-size:1.1rem; transition:transform .2s var(--ease)}
.catbtn:hover .ct .go{transform:translateX(4px)}
.catbtn .cl{color:var(--muted); font-size:.92rem; margin-top:8px; line-height:1.55}
.catbtn .cnt{align-self:flex-start; margin-top:14px; font-size:.8rem; font-weight:700; color:var(--accent);
  background:#e3f0ec; padding:4px 11px; border-radius:999px}

/* 카테고리 페이지 하단: 다른 분야 바로가기 */
.catnav{margin-top:40px; padding-top:26px; border-top:1px solid var(--line); animation:rise .6s var(--ease) both}
.catnav-label{text-align:center; color:var(--muted); font-weight:700; font-size:.9rem; letter-spacing:.03em; margin-bottom:16px}
.catnav-row{display:flex; justify-content:center; gap:14px; flex-wrap:wrap}
.catnav-row a{display:flex; flex-direction:column; align-items:center; gap:8px; text-decoration:none;
  color:var(--ink-2); width:104px; padding:16px 8px; border:1px solid var(--line); border-radius:14px;
  background:var(--card); transition:transform .18s var(--ease), border-color .18s, box-shadow .18s, color .18s}
.catnav-row a:hover{transform:translateY(-3px); border-color:var(--accent-2); box-shadow:0 12px 26px rgba(15,118,110,.14); color:var(--accent)}
.catnav-row .nico{width:42px; height:42px; border-radius:12px; background:#e3f0ec; color:var(--accent);
  display:flex; align-items:center; justify-content:center; transition:transform .2s var(--ease)}
.catnav-row a:hover .nico{transform:scale(1.08) rotate(-3deg)}
.catnav-row .nico svg{width:23px; height:23px}
.catnav-row .nt{font-size:.86rem; font-weight:700; text-align:center; line-height:1.3}

@keyframes rise{from{opacity:0; transform:translateY(14px)} to{opacity:1; transform:none}}
@keyframes rowin{from{opacity:0; transform:translateY(8px)} to{opacity:1; transform:none}}
@keyframes fade{from{opacity:0} to{opacity:1}}
@keyframes pop{from{opacity:0; transform:translateY(16px) scale(.96)} to{opacity:1; transform:none}}

@media (max-width:480px){
  .wrap{padding:24px 14px 60px}
  header h1{font-size:1.58rem}
  header p{white-space:normal; font-size:.92rem}
  .note,.disc,.lead,.acc-a p{text-align:left}
  .card{padding:22px 16px}
  .card-title{font-size:1.16rem}
  body{font-size:16px}
  label{font-size:.97rem}
  th,td{padding:11px 5px; font-size:.93rem}
  thead th{font-size:.74rem}
  .big .v{font-size:1.55rem}
  .tabs button{font-size:.96rem}
  .acc-q{font-size:1.02rem; padding:16px 32px 16px 2px}
  .seg button{font-size:.9rem; padding:11px 8px; min-width:74px}
  .ccard{padding:17px; gap:14px} .ico{width:46px; height:46px} .ico svg{width:25px; height:25px}
  .ctxt .t{font-size:1.1rem} .ctxt .d{font-size:.88rem} .cat{margin-top:26px}
  .catnav-row a{width:47%; min-width:0}
}
@media (max-width:560px){
  .cathub{grid-template-columns:1fr; gap:13px}
  .catbtn{padding:20px 18px} .catbtn .ct{font-size:1.18rem}
}

/* row 내 입력칸 하단 정렬(qhint 길이가 달라도 입력칸 라인 맞춤) */
.row-eq > div{display:flex; flex-direction:column}
.row-eq > div > input, .row-eq > div > .money-field, .row-eq > div > select{margin-top:auto}

/* 모바일에서는 2칸 행을 세로로 쌓아 겹침 방지(날짜칸 등 좁아지면 겹침) */
@media (max-width:560px){
  .row.row-stack{flex-direction:column; align-items:stretch; gap:0}
  .row.row-stack > div{width:100%; min-width:0; flex:1 1 auto}
  .row.row-stack > div + div{margin-top:14px}
}

/* ===== 전역 메뉴 (전 페이지 우상단 고정) ===== */
.navmenu{position:fixed; top:14px; right:14px; z-index:70}
.navmenu-btn{width:46px; height:46px; border-radius:13px; border:1px solid var(--line);
  background:var(--card); box-shadow:var(--shadow); cursor:pointer; display:flex;
  align-items:center; justify-content:center; color:var(--accent); padding:0;
  transition:transform .15s var(--ease), box-shadow .2s, border-color .2s}
.navmenu-btn:hover{border-color:var(--accent-2); box-shadow:0 10px 24px rgba(15,118,110,.18)}
.navmenu-btn:active{transform:translateY(1px)}
.navmenu-btn svg{width:23px; height:23px}
.navmenu-panel{position:absolute; top:54px; right:0; width:min(282px, calc(100vw - 28px)); max-height:76vh;
  overflow-y:auto; -webkit-overflow-scrolling:touch; background:var(--card); border:1px solid var(--line);
  border-radius:16px; box-shadow:0 20px 52px rgba(16,48,44,.24); padding:8px;
  opacity:0; transform:translateY(-8px) scale(.97); transform-origin:top right; pointer-events:none;
  transition:opacity .22s var(--ease), transform .22s var(--ease)}
.navmenu.open .navmenu-panel{opacity:1; transform:none; pointer-events:auto}
.navmenu .gh{font-size:.73rem; font-weight:800; letter-spacing:.04em; color:var(--muted); padding:10px 10px 4px}
.navmenu a{display:flex; align-items:center; gap:11px; padding:9px 10px; border-radius:10px;
  text-decoration:none; color:var(--ink); font-weight:600; font-size:.95rem; transition:background .15s, color .15s}
.navmenu a:hover{background:var(--soft); color:var(--accent)}
.navmenu a.cur{background:#e3f0ec; color:var(--accent)}
.navmenu a .mi{width:28px; height:28px; flex:0 0 auto; border-radius:8px; background:#e3f0ec; color:var(--accent);
  display:flex; align-items:center; justify-content:center}
.navmenu a .mi svg{width:17px; height:17px}
.navmenu a.home{font-weight:800}
.navmenu .nd{height:1px; background:var(--line); margin:6px 6px}

/* ===== 불편·요청 접수 버튼 ===== */
.feedback{text-align:center; margin-top:24px}
.feedback-btn{display:inline-flex; align-items:center; gap:8px; background:transparent; color:var(--accent);
  border:1px solid var(--accent-2); border-radius:999px; padding:11px 20px; font-weight:700; font-size:.95rem;
  font-family:inherit; cursor:pointer; text-decoration:none; transition:background .15s, transform .12s}
.feedback-btn:hover{background:#e3f0ec} .feedback-btn:active{transform:translateY(1px)}
.feedback-btn svg{width:17px; height:17px}
.feedback-note{color:var(--muted); font-size:.82rem; margin-top:9px; line-height:1.6}
.fb-modal h3{margin:0 0 8px}
.fb-field{margin-top:14px}
.fb-field label{display:block; font-size:.92rem; font-weight:700; color:var(--ink); margin-bottom:6px}
.fb-modal textarea, .fb-modal input[type=email]{width:100%; padding:12px 14px; background:var(--soft);
  border:1px solid var(--line); border-radius:9px; font-family:inherit; font-size:1rem; color:var(--ink);
  outline:none; transition:border-color .15s, box-shadow .15s}
.fb-modal textarea{min-height:118px; resize:vertical; line-height:1.6}
.fb-modal textarea:focus, .fb-modal input[type=email]:focus{border-color:var(--accent); box-shadow:0 0 0 3px rgba(15,118,110,.14)}
.fb-actions{display:flex; gap:10px; margin-top:18px}
.fb-actions button{flex:1; padding:13px; border-radius:9px; font-weight:700; font-family:inherit; font-size:1rem; cursor:pointer; border:1px solid var(--line); transition:background .15s, border-color .15s, color .15s}
.fb-send{flex:1.6 !important; background:var(--accent); color:#fff; border-color:var(--accent)}
.fb-send:hover{background:#0c5d57}
.fb-send:disabled{opacity:.6; cursor:default}
.fb-cancel{background:transparent; color:var(--muted)}
.fb-cancel:hover{border-color:var(--accent); color:var(--accent)}
.fb-status{margin-top:12px; font-size:.92rem; line-height:1.55; display:none}
.fb-status.show{display:block}
.fb-status.ok{color:var(--accent)}
.fb-status.bad{color:var(--warn)}
.fb-hp{position:absolute !important; left:-9999px; width:1px; height:1px; opacity:0; pointer-events:none}

@media (max-width:480px){
  .navmenu{top:10px; right:10px}
  .navmenu-btn{width:42px; height:42px; border-radius:11px}
}
