:root{font-family:Pretendard,Noto Sans KR,Malgun Gothic,sans-serif;color:#0f172a;background:#f8fafc}*{box-sizing:border-box}html{scrollbar-gutter:stable}body{margin:0;min-width:320px}#app{width:100%}.page{width:100%;padding:20px}.panel{position:relative;max-width:1280px;margin:34px auto;background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:20px}.panel-title{position:absolute;top:-33px;left:14px;font-size:13px;font-weight:700;color:#0f172a;background:#f1f5f9;border:1px solid #e2e8f0;border-bottom:0;border-radius:10px 10px 0 0;padding:7px 16px}.panel-tabs{position:absolute;top:-34px;left:14px;display:flex;gap:4px}.panel-tab{font-size:14px;font-weight:600;color:#64748b;background:#f1f5f9;border:1px solid #e2e8f0;border-bottom:0px;border-radius:10px 10px 0 0;padding:8px 20px;cursor:pointer;transition:all .2s;margin:0;font-family:inherit}.panel-tab:hover{background:#e2e8f0;color:#334155}.panel-tab.active{color:#0f172a;background:#fff;padding-bottom:9px;margin-bottom:-1px;z-index:1}button{border:1px solid #cbd5e1;background:#fff;border-radius:8px;padding:8px 14px;font-size:13px;cursor:pointer;font-family:inherit;color:#0f172a}button:disabled{opacity:.45;cursor:not-allowed}button.primary{background:#0f172a;border-color:#0f172a;color:#fff}button.danger{background:#fee2e2;border-color:#fecaca;color:#991b1b}input,select,textarea{width:100%;margin-top:6px;border:1px solid #cbd5e1;border-radius:8px;padding:10px;font-size:14px;font-family:inherit;color:#0f172a;background:#fff;outline:none}input:focus,select:focus,textarea:focus{border-color:#94a3b8;box-shadow:0 0 0 3px #94a3b826}label{font-size:14px;color:#334155;display:block}.grid{display:grid;gap:12px;margin-bottom:16px}.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.calc-section{border:1px solid #e2e8f0;border-radius:10px;padding:16px;margin-bottom:16px}.section-title{margin:0 0 14px;font-size:15px;font-weight:700;color:#0f172a}.info-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:14px 16px;margin-bottom:16px}.info-card-title{margin:0 0 10px;font-size:14px;font-weight:700;color:#334155}.info-row{display:flex;align-items:baseline;gap:6px;font-size:13px;color:#475569;padding:3px 0}.info-num{font-weight:700;color:#334155;flex:0 0 16px}.info-highlight{color:#0f172a;font-weight:700}.search-row{display:flex;gap:8px;align-items:flex-start;flex-shrink:0}.search-row input{margin:0;flex:1;min-width:0}.search-row button{flex:0 0 auto;white-space:nowrap;margin:0;align-self:stretch}.search-msg{text-align:center;padding:20px;color:#64748b;font-size:14px;flex-shrink:0}.search-results-list{display:flex;flex-direction:column;border:1px solid #e2e8f0;border-radius:8px;overflow-y:auto;overflow-x:hidden;flex:1;min-height:0}.addr-item{display:flex;flex-direction:column;align-items:flex-start;padding:12px 16px;border:none;border-bottom:1px solid #e2e8f0;background:#fff;cursor:pointer;text-align:left;border-radius:0}.addr-item:last-child{border-bottom:none}.addr-item:hover{background:#f8fafc}.loading-spinner{display:flex;align-items:center;gap:8px;margin-top:12px;font-size:13px;color:#475569}.spinner{width:18px;height:18px;border:2px solid #e2e8f0;border-top-color:#475569;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.search-results{margin-top:12px;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.search-results-header{padding:8px 12px;background:#f8fafc;border-bottom:1px solid #e2e8f0;font-size:13px;font-weight:600;color:#334155}.result-count{font-weight:400;color:#64748b;margin-left:6px}.results-list{max-height:240px;overflow-y:auto}.address-item{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background .12s}.address-item:last-child{border-bottom:0}.address-item:hover{background:#f8fafc}.address-item-main{flex:1;min-width:0}.address-full{font-size:13px;color:#0f172a;font-weight:500}.address-type{font-size:12px;color:#64748b;margin-top:2px}.select-btn{flex:0 0 auto;padding:5px 10px;font-size:12px}.no-results{padding:24px;text-align:center;font-size:13px;color:#64748b}.field-note{margin-top:4px;font-size:12px;color:#94a3b8}.form-actions{display:flex;gap:8px;margin-top:4px}.form-actions>button{flex:1}.edit-buttons{display:flex;gap:8px;flex:1}.edit-buttons button{flex:1}.result-grid{border:1px solid #e2e8f0;border-radius:10px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));overflow:hidden;margin-bottom:12px}.result-grid>div{padding:10px 12px;border-top:1px solid #e2e8f0;border-right:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:baseline;gap:8px;font-size:13px}.result-grid>div:nth-child(-n+3){border-top:0}.result-grid>div:nth-child(3n){border-right:0}.result-grid span{color:#475569;white-space:nowrap}.result-grid strong{color:#0f172a;text-align:right;word-break:break-all}.charge-result{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:12px;font-size:14px}.charge-result span{color:#334155;font-weight:600}.charge-result strong{font-size:20px;font-weight:700;color:#0f172a}.formula-label{font-size:13px;font-weight:600;color:#334155;margin-bottom:6px}.formula-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:12px;overflow-x:auto}.formula-box pre{margin:0;font-family:Pretendard,Noto Sans KR,monospace;font-size:13px;color:#334155;line-height:1.7;white-space:pre-wrap;word-break:break-all}.list-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.list-header .section-title{margin:0}.list-actions{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.table-scroll{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{border-top:1px solid #e2e8f0;padding:8px 10px;font-size:13px;text-align:left;vertical-align:middle}thead th{background:#f8fafc;font-weight:600;color:#334155;text-align:center;border-top:0;border-bottom:1px solid #e2e8f0;white-space:nowrap}tbody tr:hover{background:#f8fafc}tbody tr.editing-row{background:#fffbeb;outline:2px solid #fbbf24;outline-offset:-1px}td.text-center{text-align:center}td.text-right{text-align:right}td.mono{font-family:Pretendard,monospace;font-size:12px;color:#475569}td.charge-cell{text-align:right;font-weight:600;color:#0f172a}td.empty-row{text-align:center;padding:32px;color:#94a3b8;font-size:14px}td.cap-note{font-size:11px;color:#b45309}.row-actions{display:flex;gap:4px;justify-content:center}.row-actions button{padding:4px 8px;font-size:12px}.btn-edit{color:#334155}.btn-delete{background:#fee2e2;border-color:#fecaca;color:#991b1b}.total-row{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;margin-top:12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px}.total-row span{font-size:14px;font-weight:600;color:#334155}.total-row strong{font-size:20px;font-weight:700;color:#0f172a}.legal-ref{font-size:12px;color:#64748b;margin-top:24px;line-height:1.6;display:flex;flex-direction:column;gap:4px}.disclaimer{margin-top:12px;font-size:11px;color:#94a3b8}.calculator-container{display:flex;flex-direction:column;gap:16px}.actions{display:flex;gap:8px;align-items:center;margin-top:10px}.set-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #f1f5f9}.modal-overlay{position:fixed;inset:0;background:#0f172a99;display:flex;align-items:center;justify-content:center;z-index:9999}.modal-content{background:#fff;width:100%;max-width:500px;border-radius:12px;box-shadow:0 10px 25px #0000001a;display:flex;flex-direction:column;max-height:80vh;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e2e8f0;flex-shrink:0}.modal-header h3{margin:0;font-size:16px}.close-btn{background:transparent;border:none;font-size:20px;cursor:pointer;padding:0;color:#64748b}.modal-body{padding:20px;display:flex;flex-direction:column;gap:16px;flex:1;min-height:0}.hidden{display:none!important}.toast{position:fixed;right:20px;top:20px;padding:10px 14px;border-radius:8px;color:#fff;font-size:14px;font-family:inherit;z-index:9999;pointer-events:none}.toast.success{background:#166534}.toast.error{background:#991b1b}.toast.info{background:#475569}@media(max-width:1100px){.result-grid{grid-template-columns:repeat(1,minmax(0,1fr))}.result-grid>div{border-right:0}.result-grid>div:nth-child(-n+3){border-top:1px solid #e2e8f0}.result-grid>div:first-child{border-top:0}}@media(max-width:900px){.page{padding:12px}.panel{margin-top:12px;padding:14px}.panel-title{position:static;display:inline-block;border-radius:8px;border:1px solid #cbd5e1;margin-bottom:12px}.cols-2{grid-template-columns:repeat(1,minmax(0,1fr))}.list-header{flex-direction:column;align-items:flex-start}}
