:root{--primary-blue: #0288d1;--secondary-blue: #03a9f4;--accent-yellow: #fbc02d;--bg-light-blue: #f0faff;--bg-white: #ffffff;--text-dark: #333333;--text-light: #ecf0f1;--border-color: #dee2e6;--shadow: 0 4px 6px rgba(0, 0, 0, .1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Helvetica Neue,Arial,Hiragino Kaku Gothic ProN,Hiragino Sans,Meiryo,sans-serif;background-color:var(--bg-light-blue);color:var(--text-dark);height:100vh;display:flex;flex-direction:column}header{background-color:var(--primary-blue);color:var(--text-light);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow);border-bottom:3px solid var(--accent-yellow);z-index:1000}header h1{font-size:1.5rem;font-weight:600;letter-spacing:.05em}.main-container{flex:1;display:flex;overflow:hidden}.map-section{flex:1;position:relative;display:flex;flex-direction:column}#map{flex:1;width:100%}.search-container{position:absolute;top:20px;left:50%;transform:translate(-50%);z-index:1000;display:flex;gap:10px;background:#ffffffe6;padding:10px;border-radius:12px;box-shadow:0 4px 15px #00000026;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);width:90%;max-width:600px}#address-input{flex:1;padding:10px 15px;border:1px solid var(--border-color);border-radius:8px;font-size:.95rem;outline:none;transition:border-color .2s}#address-input:focus{border-color:var(--primary-blue)}.sidebar{width:330px;background-color:var(--bg-white);border-left:1px solid var(--border-color);padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem;overflow-y:auto;box-shadow:-2px 0 10px #0000000d}.panel{background:var(--bg-white);border-radius:8px;padding:1.5rem;border:1px solid var(--border-color)}.panel-title{font-weight:700;font-size:1.1rem;color:var(--primary-blue);margin-bottom:1rem;border-bottom:2px solid var(--primary-blue);padding-bottom:.5rem}.controls{display:flex;flex-direction:column;gap:1rem}.btn{padding:.8rem 1.5rem;border:none;border-radius:4px;font-weight:700;cursor:pointer;transition:all .3s ease;font-size:1rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary{background-color:var(--primary-blue);color:#fff}.btn-primary:hover{background-color:var(--secondary-blue);transform:translateY(-2px);box-shadow:0 4px 8px #0003}.btn-outline{background-color:transparent;border:2px solid var(--primary-blue);color:var(--primary-blue)}.btn-outline:hover{background-color:var(--primary-blue);color:#fff}.btn-accent{background-color:var(--accent-yellow);color:#333}.btn-accent:hover{background-color:#f9a825;transform:translateY(-2px)}.input-unit{display:flex;align-items:center;gap:8px}.input-unit span{font-size:.9rem;color:#666}.results{display:flex;flex-direction:column;gap:1rem}.result-item{display:flex;justify-content:space-between;align-items:baseline;padding:.5rem 0;border-bottom:1px dashed var(--border-color)}.result-label{font-size:.9rem;color:#666}.result-value{font-size:1.2rem;font-weight:700;color:var(--primary-blue)}.kagechi-ratio{margin-top:1rem;padding:1rem;background-color:#fff4f2;border:1px solid #ffcfc9;border-radius:4px;text-align:center}.kagechi-ratio .result-label{display:block;margin-bottom:.5rem}.kagechi-ratio .result-value{font-size:2rem;color:var(--primary-blue)}.instructions{font-size:.85rem;color:#555;line-height:1.5;padding:1rem;background:#e9ecef;border-radius:4px}@media (max-width: 900px){.main-container{flex-direction:column}.sidebar{width:100%;height:auto;border-left:none;border-top:1px solid var(--border-color);padding:1rem}#map{height:50vh}}@media print{body,html{overflow:visible!important;height:auto!important;background-color:#fff!important}header,.search-container,.controls,.instructions,.print-btn{display:none!important}.sidebar .panel:first-child{display:none!important}.main-container{flex-direction:column!important;display:block!important;overflow:visible!important;height:auto!important;padding:0!important;align-items:flex-start!important}.map-section{flex:none!important;width:100%!important;height:500px!important;overflow:visible!important}.sidebar{width:100%!important;display:block!important;border:none!important;padding:20px 0 0!important;margin-top:20px!important;page-break-before:always!important;overflow:visible!important;height:auto!important}.panel{box-shadow:none!important;border:1px solid #ccc!important;page-break-inside:avoid!important;overflow:visible!important;height:auto!important;width:100%!important}}
