/* =====================================================================
   이웃집 개발자 — 스타일
   컨셉: 동네 이웃 같은 따뜻함. 둥근 카드 + 코랄/그린 + 종이 질감.
   ===================================================================== */

@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable-dynamic-subset.css");

/* 친근한 라운드 디스플레이체(없으면 Pretendard 로 폴백) */
@font-face{
  font-family:'GmarketSansBold';
  src:url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2001@1.1/GmarketSansBold.woff') format('woff');
  font-weight:700; font-display:swap;
}

:root{
  --paper:#FFF9F4;
  --paper-2:#FBF1E8;
  --card:#FFFFFF;
  --ink:#2A2622;
  --ink-soft:#6E6358;
  --ink-faint:#A99E92;
  --coral:#FF6B45;
  --coral-dark:#E8542F;
  --coral-soft:#FFEAE1;
  --green:#34A878;
  --green-dark:#268560;
  --green-soft:#E2F4EC;
  --line:#EFE4D7;
  --line-2:#E4D6C6;
  --radius:18px;
  --radius-lg:26px;
  --radius-sm:12px;
  --shadow:0 8px 24px rgba(180,120,80,.10);
  --shadow-sm:0 3px 10px rgba(180,120,80,.08);
  --maxw:1080px;
  --display:'GmarketSansBold','Pretendard Variable',-apple-system,'Apple SD Gothic Neo','Malgun Gothic',sans-serif;
  --body:'Pretendard Variable',-apple-system,BlinkMacSystemFont,'Apple SD Gothic Neo','Malgun Gothic',sans-serif;
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--body); font-size:16px; line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit; text-decoration:none;}
img{max-width:100%; display:block;}
button,input,textarea,select{font-family:inherit; font-size:inherit;}

.wrap{max-width:var(--maxw); margin:0 auto; padding:0 20px;}
.muted{color:var(--ink-soft);}
.center{text-align:center;}

/* ---------- 헤더 ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,249,244,.86); backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.site-header .wrap{display:flex; align-items:center; gap:16px; height:66px;}
.brand{display:flex; align-items:center; gap:10px; font-family:var(--display); font-size:20px; color:var(--ink);}
.brand .dot{width:30px; height:30px; border-radius:50%; background:var(--coral); position:relative; flex:0 0 auto;}
.brand .dot::after{content:""; position:absolute; right:-4px; bottom:-2px; width:13px; height:13px; border-radius:50%; background:var(--green);}
.nav{margin-left:auto; display:flex; align-items:center; gap:6px;}
.nav a{padding:8px 14px; border-radius:999px; color:var(--ink-soft); font-weight:500;}
.nav a:hover{background:var(--paper-2); color:var(--ink);}
.nav a.cta{background:var(--coral); color:#fff;}
.nav a.cta:hover{background:var(--coral-dark);}
.nav-toggle{display:none; margin-left:auto; background:none; border:0; padding:8px; cursor:pointer;}
.nav-toggle span{display:block; width:22px; height:2px; background:var(--ink); margin:4px 0; border-radius:2px;}

/* ---------- 버튼 ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:13px 22px; border-radius:999px; border:0; cursor:pointer;
  font-weight:700; font-size:16px; line-height:1; transition:.15s;
}
.btn-primary{background:var(--coral); color:#fff;}
.btn-primary:hover{background:var(--coral-dark);}
.btn-green{background:var(--green); color:#fff;}
.btn-green:hover{background:var(--green-dark);}
.btn-ghost{background:#fff; color:var(--ink); border:1.5px solid var(--line-2);}
.btn-ghost:hover{border-color:var(--coral); color:var(--coral-dark);}
.btn-lg{padding:16px 30px; font-size:17px;}
.btn-block{display:flex; width:100%;}
.btn[disabled]{opacity:.5; cursor:not-allowed;}

/* ---------- 히어로 ---------- */
.hero{padding:70px 0 40px; position:relative; overflow:hidden;}
.hero .eyebrow{
  display:inline-flex; align-items:center; gap:7px;
  background:var(--green-soft); color:var(--green-dark);
  padding:7px 14px; border-radius:999px; font-weight:700; font-size:14px;
}
.hero h1{
  font-family:var(--display); font-weight:700;
  font-size:clamp(30px,5.4vw,52px); line-height:1.22; letter-spacing:-.01em;
  margin:18px 0 16px;
}
.hero p.lead{font-size:clamp(16px,2.2vw,19px); color:var(--ink-soft); max-width:560px; margin:0 0 28px;}
.hero .cta-row{display:flex; gap:12px; flex-wrap:wrap;}
.hero .price-chip{
  display:inline-flex; align-items:center; gap:8px; margin-top:22px;
  background:#fff; border:1.5px dashed var(--coral); color:var(--coral-dark);
  padding:9px 16px; border-radius:999px; font-weight:700;
}
/* 손그림 느낌 점선 강조(시그니처) */
.squiggle{width:120px; height:14px; color:var(--coral); margin:6px 0 0;}
.squiggle path{stroke:currentColor; stroke-width:3.5; fill:none; stroke-linecap:round;}

/* 히어로 배경의 동네 일러스트(연한 도형) */
.hero-art{position:absolute; right:-40px; top:30px; width:380px; opacity:.9; pointer-events:none;}
@media(max-width:860px){ .hero-art{display:none;} }

/* ---------- 섹션 공통 ---------- */
.section{padding:54px 0;}
.section.alt{background:var(--paper-2); border-top:1px solid var(--line); border-bottom:1px solid var(--line);}
.section-head{margin-bottom:28px;}
.section-head h2{font-family:var(--display); font-size:clamp(24px,3.4vw,32px); margin:0 0 8px; letter-spacing:-.01em;}
.section-head p{color:var(--ink-soft); margin:0;}

/* ---------- 카드 ---------- */
.cards{display:grid; gap:18px; grid-template-columns:repeat(3,1fr);}
.cards.cols-2{grid-template-columns:repeat(2,1fr);}
@media(max-width:820px){ .cards,.cards.cols-2{grid-template-columns:1fr;} }
.card{
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius);
  padding:22px; box-shadow:var(--shadow-sm);
}
.card.hover:hover{box-shadow:var(--shadow); transform:translateY(-2px); transition:.15s;}
.card .ico{
  width:46px; height:46px; border-radius:14px; display:grid; place-items:center;
  background:var(--coral-soft); color:var(--coral-dark); margin-bottom:14px; font-size:22px;
}
.card .ico.g{background:var(--green-soft); color:var(--green-dark);}
.card h3{margin:0 0 6px; font-size:18px;}
.card p{margin:0; color:var(--ink-soft); font-size:15px;}

/* ---------- 진행 단계 ---------- */
.steps{display:grid; gap:14px; grid-template-columns:repeat(3,1fr); counter-reset:step;}
@media(max-width:820px){ .steps{grid-template-columns:1fr;} }
.step{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:20px 20px 20px 60px; position:relative;
}
.step::before{
  counter-increment:step; content:counter(step);
  position:absolute; left:18px; top:18px;
  width:30px; height:30px; border-radius:50%; background:var(--coral); color:#fff;
  display:grid; place-items:center; font-family:var(--display); font-size:15px;
}
.step h4{margin:0 0 4px; font-size:16px;}
.step p{margin:0; color:var(--ink-soft); font-size:14px;}
.step.green::before{background:var(--green);}

/* ---------- 포트폴리오 ---------- */
.pf-card{overflow:hidden; padding:0;}
.pf-thumb{aspect-ratio:16/10; background:var(--paper-2); display:grid; place-items:center; color:var(--ink-faint);}
.pf-thumb img{width:100%; height:100%; object-fit:cover;}
.pf-body{padding:18px 20px 20px;}
.pf-cat{display:inline-block; font-size:13px; font-weight:700; color:var(--green-dark); background:var(--green-soft); padding:3px 10px; border-radius:999px; margin-bottom:8px;}
.pf-price{font-weight:700; color:var(--coral-dark); margin-top:8px;}
.pf-video{aspect-ratio:16/9; width:100%; border:0; border-radius:var(--radius-sm);}

/* ---------- 폼 / 쪽지 느낌 ---------- */
.note-form{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg);
  box-shadow:var(--shadow); padding:30px; position:relative;
}
.note-form::before{
  content:""; position:absolute; left:50%; top:-12px; transform:translateX(-50%);
  width:90px; height:22px; background:var(--coral-soft); border:1.5px solid var(--coral);
  border-radius:6px; opacity:.85;
}
.field{margin-bottom:18px;}
.field > label{display:block; font-weight:700; margin-bottom:7px; font-size:15px;}
.field .hint{color:var(--ink-faint); font-weight:400; font-size:13px; margin-left:6px;}
.input,.textarea,select.input{
  width:100%; padding:13px 15px; border:1.5px solid var(--line-2); border-radius:var(--radius-sm);
  background:#fff; color:var(--ink); transition:.15s;
}
.input:focus,.textarea:focus,select.input:focus{outline:none; border-color:var(--coral); box-shadow:0 0 0 3px var(--coral-soft);}
.textarea{min-height:130px; resize:vertical; line-height:1.6;}
.row2{display:grid; grid-template-columns:1fr 1fr; gap:14px;}
@media(max-width:560px){ .row2{grid-template-columns:1fr;} }
.form-note{font-size:13px; color:var(--ink-faint); margin-top:4px;}

/* 카테고리 칩 선택 */
.chips{display:flex; flex-wrap:wrap; gap:8px;}
.chip{
  padding:8px 14px; border-radius:999px; border:1.5px solid var(--line-2);
  background:#fff; cursor:pointer; font-size:14px; font-weight:500; user-select:none;
}
.chip input{display:none;}
.chip.on{border-color:var(--coral); background:var(--coral-soft); color:var(--coral-dark); font-weight:700;}

/* ---------- 배지 ---------- */
.badge{display:inline-block; padding:3px 11px; border-radius:999px; font-size:13px; font-weight:700; white-space:nowrap;}
.st-new{background:#EEF1F4; color:#5B6470;}
.st-quote{background:#FFF3D9; color:#9A6B00;}
.st-paid{background:var(--green-soft); color:var(--green-dark);}
.st-dev{background:#E5EEFB; color:#1F5FB0;}
.st-done{background:var(--coral-soft); color:var(--coral-dark);}
.st-cancel{background:#F6E7E7; color:#9A3A3A;}

/* ---------- 알림 박스 ---------- */
.alert{padding:14px 18px; border-radius:var(--radius-sm); margin-bottom:18px; font-weight:500;}
.alert-ok{background:var(--green-soft); color:var(--green-dark); border:1px solid #BFE6D4;}
.alert-warn{background:#FFF3D9; color:#8A5E00; border:1px solid #F2DCA0;}
.alert-err{background:#F8E7E7; color:#9A3A3A; border:1px solid #ECC9C9;}

/* ---------- 완료 화면 ---------- */
.key-box{
  font-family:'GmarketSansBold',var(--body); letter-spacing:.06em;
  font-size:clamp(20px,4vw,28px); text-align:center;
  background:#fff; border:2px dashed var(--coral); color:var(--coral-dark);
  border-radius:var(--radius); padding:22px; margin:18px 0;
}

/* ---------- 푸터 ---------- */
.site-footer{background:var(--paper-2); border-top:1px solid var(--line); margin-top:30px; padding:34px 0;}
.site-footer .wrap{display:flex; flex-wrap:wrap; gap:14px; align-items:center; justify-content:space-between; color:var(--ink-soft); font-size:14px;}
.site-footer .brand{font-size:17px;}

/* =====================================================================
   관리자(admin) 스타일
   ===================================================================== */
.adm-body{background:#F6F2EC;}
.adm-top{background:#fff; border-bottom:1px solid var(--line); position:sticky; top:0; z-index:40;}
.adm-top .wrap{display:flex; align-items:center; gap:14px; height:60px;}
.adm-top .brand{font-size:17px;}
.adm-nav{margin-left:auto; display:flex; gap:4px; flex-wrap:wrap;}
.adm-nav a{padding:7px 13px; border-radius:10px; color:var(--ink-soft); font-weight:500; font-size:14px;}
.adm-nav a:hover,.adm-nav a.on{background:var(--coral-soft); color:var(--coral-dark);}
.adm-main{max-width:1140px; margin:0 auto; padding:26px 20px 60px;}
.adm-h{display:flex; align-items:center; gap:12px; margin:0 0 20px;}
.adm-h h1{font-size:22px; margin:0; font-family:var(--display);}

.stat-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:24px;}
@media(max-width:780px){ .stat-grid{grid-template-columns:repeat(2,1fr);} }
.stat{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:18px;}
.stat .n{font-family:var(--display); font-size:28px; line-height:1;}
.stat .l{color:var(--ink-soft); font-size:14px; margin-top:6px;}

.panel{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:0; overflow:hidden; margin-bottom:22px;}
.panel-h{padding:16px 20px; border-bottom:1px solid var(--line); font-weight:700; display:flex; align-items:center; gap:10px;}

.table{width:100%; border-collapse:collapse; font-size:14px;}
.table th,.table td{padding:12px 14px; text-align:left; border-bottom:1px solid var(--line); vertical-align:middle;}
.table th{background:#FAF6F0; color:var(--ink-soft); font-weight:700; font-size:13px;}
.table tr:last-child td{border-bottom:0;}
.table td .row-actions{display:flex; gap:8px; align-items:center;}
.table .num{font-variant-numeric:tabular-nums;}
.table-wrap{overflow-x:auto;}

.adm-form .field{margin-bottom:16px;}
.adm-form label{font-weight:700; font-size:14px; display:block; margin-bottom:6px;}
.adm-form .input,.adm-form .textarea,.adm-form select.input{max-width:480px;}
.btn-sm{padding:8px 14px; font-size:14px; border-radius:10px;}
.link{color:var(--coral-dark); font-weight:700;}
.dl{display:grid; grid-template-columns:130px 1fr; gap:10px 16px; font-size:15px;}
.dl dt{color:var(--ink-soft);}
.dl dd{margin:0;}

.login-wrap{min-height:100vh; display:grid; place-items:center; padding:20px;}
.login-card{background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); box-shadow:var(--shadow); padding:34px; width:100%; max-width:380px;}

/* ---------- 반응형 네비 ---------- */
@media(max-width:760px){
  .nav{display:none;}
  .nav.open{display:flex; position:absolute; top:66px; left:0; right:0; flex-direction:column; align-items:stretch; gap:0; background:var(--paper); border-bottom:1px solid var(--line); padding:8px 16px 16px;}
  .nav.open a{padding:12px 8px;}
  .nav.open a.cta{margin-top:8px; text-align:center;}
  .nav-toggle{display:block;}
}
