@import"https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;600;700&display=swap";:root{--primary: #8a3f34;--primary-dark: #5b2b23;--primary-light: #f5ded8;--secondary: #1d2758;--secondary-dark: #11183d;--accent: #be3b45;--success: #4f7b4a;--warning: #b56a2a;--danger: #a8363c;--cream: #fff7ea;--cream-deep: #f6e2c8;--earth: #6f4a36;--leaf: #697c43;--gray-50: #fafafa;--gray-100: #f5f5f5;--gray-200: #eeeeee;--gray-300: #e0e0e0;--gray-400: #bdbdbd;--gray-500: #9e9e9e;--gray-600: #757575;--gray-700: #616161;--gray-800: #424242;--gray-900: #212121;--bg-primary: #ffffff;--bg-card: #ffffff;--bg-overlay: rgba(0, 0, 0, .5);--shadow-sm: 0 1px 2px rgba(47, 30, 20, .04);--shadow-md: 0 2px 8px rgba(80, 52, 34, .07);--shadow-lg: 0 8px 18px rgba(80, 52, 34, .1);--shadow-xl: 0 12px 28px rgba(80, 52, 34, .12);--radius-sm: 2px;--radius-md: 4px;--radius-lg: 6px;--radius-full: 50px;--transition-fast: .15s ease;--transition-base: .3s ease;--transition-slow: .5s ease}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px}body{font-family:Noto Sans JP,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:#362820;line-height:1.6;min-height:100vh}a{color:inherit}#root{min-height:100vh;display:flex;flex-direction:column}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 22px;font-size:1rem;font-weight:600;border:none;border-radius:3px;cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary-dark);color:#fff;box-shadow:none}.btn-primary:hover:not(:disabled){background:var(--primary)}.btn-secondary{background:#f4eadb;color:var(--primary-dark);border:1px solid #dfc6a6}.btn-secondary:hover:not(:disabled){background:var(--gray-200)}.btn-success{background:var(--leaf);color:#fff;box-shadow:none}.btn-success:hover:not(:disabled){background:#5f7545}.btn-danger{background:var(--danger);color:#fff}.btn-outline{background:transparent;border:1px solid var(--primary);color:var(--primary-dark)}.btn-outline:hover:not(:disabled){background:var(--primary);color:#fff}.btn-sm{padding:8px 16px;font-size:.875rem}.btn-lg{padding:16px 32px;font-size:1.125rem}.btn-block{width:100%}.card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:none;padding:24px;border:1px solid #dedede}.card-header{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--gray-200)}.card-title{font-size:1.25rem;font-weight:600;color:var(--primary-dark)}.form-group{margin-bottom:20px}.form-label{display:block;font-size:.875rem;font-weight:700;color:var(--primary-dark);margin-bottom:8px}.form-label.required:after{content:" *";color:var(--danger)}.form-input,.form-select,.form-textarea{width:100%;padding:12px 16px;font-size:1rem;font-family:inherit;border:1px solid #cfcfcf;border-radius:var(--radius-md);background:#fff;transition:border-color var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #8a3f341f}.form-textarea{min-height:100px;resize:vertical}.form-hint{font-size:.8rem;color:#6f5a49;margin-top:4px}.form-error{font-size:.8rem;color:var(--danger);margin-top:4px}.selector-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(116px,1fr));gap:12px}.selector-option{min-height:54px;padding:12px 14px;text-align:center;border:1px solid #d5d5d5;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);background:#fff;color:#423027;display:flex;align-items:center;justify-content:center;gap:8px}.selector-option:hover{border-color:var(--primary);background:#fafafa}.selector-option.selected{border-color:var(--primary);background:#f3dfd1;color:var(--primary-dark)}.selector-option small{font-size:.84rem;line-height:1.35}.selector-option.disabled{opacity:.4;cursor:not-allowed;background:var(--gray-100)}.selector-option.disabled:hover{border-color:var(--gray-300);background:var(--gray-100)}.header{background:#fff;box-shadow:none;padding:12px 24px;position:sticky;top:0;z-index:100;border-bottom:1px solid #dedede}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.header-logo{font-weight:700;color:var(--secondary);text-decoration:none;display:flex;align-items:center;gap:10px}.header-logo-image{width:52px;height:52px;object-fit:cover;border:1px solid #dedede;border-radius:3px}.header-logo-text{display:flex;flex-direction:column;line-height:1.12;font-size:1.12rem}.header-logo-sub{color:var(--earth);font-size:.72rem;font-weight:700;letter-spacing:0}.header-nav{display:flex;gap:16px}.container{width:100%;max-width:800px;margin:0 auto;padding:28px 20px;flex:1}.container-wide{max-width:1200px}.brand-kicker{color:var(--earth);font-size:.82rem;font-weight:600;letter-spacing:0;margin-bottom:10px}.home-hero{position:relative;overflow:hidden;padding:32px 24px;margin-bottom:20px;border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid #dedede;box-shadow:none}.home-hero:after{content:none}.home-hero h1,.page-heading h1{color:var(--secondary);font-size:clamp(1.75rem,6vw,2.45rem);line-height:1.25;margin-bottom:12px}.home-hero p{max-width:600px;color:#564437;font-size:1rem;line-height:1.85;margin-bottom:22px}.home-hero-actions{display:flex;flex-wrap:wrap;gap:12px}.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px}.info-panel,.notice-panel{background:var(--bg-card);border:1px solid #dedede;border-radius:var(--radius-lg);box-shadow:none}.info-panel{padding:18px}.info-label{display:block;color:var(--earth);font-size:.78rem;font-weight:700;margin-bottom:6px}.info-panel strong{display:block;color:var(--primary-dark);font-size:1.25rem;margin-bottom:8px}.info-panel p{color:#6f5a49;font-size:.9rem}.notice-panel{padding:20px}.notice-panel h2{color:var(--primary-dark);font-size:1.25rem;margin-bottom:12px}.notice-panel ul{padding-left:1.2rem;color:#564437}.notice-panel li+li{margin-top:8px}.center-action{display:flex;justify-content:center;margin-top:28px}.site-footer{text-align:center;padding:34px 20px 42px;margin-top:28px;border-top:1px solid #dedede;color:#715d4a;font-size:.9rem}.site-footer a{display:inline-block;margin-top:10px;color:#8f7861;text-decoration:none}.page-heading{text-align:center;margin-bottom:18px}.page-heading p{color:#6f5a49}.reservation-card{padding:0;overflow:hidden;border-radius:4px}.reservation-card .steps{margin:0;padding:14px 18px;border:0;border-bottom:1px solid #dedede;border-radius:0;background:#fafafa}.reservation-card>div:not(.steps){padding:22px}.reservation-card .form-group{margin-bottom:22px;padding-bottom:22px;border-bottom:1px solid #e5e5e5}.reservation-card .form-group:last-of-type{border-bottom:0}.reservation-card .selector-grid{gap:8px}.reservation-card .selector-option{border-radius:3px}.reservation-card .selector-option.selected{box-shadow:inset 3px 0 0 var(--primary)}.steps{display:flex;justify-content:center;margin-bottom:24px;padding:10px;background:#fffaf2;border-radius:var(--radius-md);border:1px solid rgba(122,83,52,.12)}.step{display:flex;align-items:center;gap:8px}.step-number{width:30px;height:30px;border-radius:var(--radius-sm);background:#ead8bf;color:var(--earth);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem}.step.active .step-number{background:#6b3a2e;color:#fff}.step.completed .step-number{background:var(--leaf);color:#fff}.step-label{font-size:.875rem;color:var(--gray-500)}.step.active .step-label{color:var(--primary-dark);font-weight:700}.step-divider{width:40px;height:2px;background:#dfc6a6;margin:0 8px}.badge{display:inline-flex;align-items:center;padding:4px 12px;font-size:.75rem;font-weight:600;border-radius:3px}.badge-pending{background:var(--warning);color:#fff}.badge-confirmed{background:var(--success);color:#fff}.badge-cancelled{background:var(--gray-400);color:#fff}.modal-overlay{position:fixed;inset:0;background:var(--bg-overlay);display:flex;align-items:center;justify-content:center;padding:24px;z-index:1000;animation:fadeIn .2s ease}.modal{background:#fff;border-radius:var(--radius-lg);max-width:500px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}.modal-header{padding:20px 24px;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;align-items:center}.modal-title{font-size:1.25rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--gray-500);padding:4px}.modal-close:hover{color:var(--gray-800)}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--gray-200);display:flex;gap:12px;justify-content:flex-end}.table-wrapper{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--gray-200)}.table th{background:var(--gray-100);font-weight:600;font-size:.875rem;color:var(--gray-700)}.table tr:hover{background:var(--gray-50)}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px}.login-card{max-width:400px;width:100%}.login-icon{display:inline-flex;align-items:center;justify-content:center;min-width:76px;min-height:38px;border-radius:3px;background:#fff4e5;color:var(--primary-dark);font-size:.95rem;font-weight:700;text-align:center;margin-bottom:16px}.alert{padding:12px 16px;border-radius:var(--radius-md);margin-bottom:16px}.alert-info{background:#fff4e5;color:var(--primary-dark);border:1px solid #dfc6a6}.alert-warning{background:#fff3e0;color:#8c4c18;border:1px solid #e3b77d}.alert-success{background:#eef5e9;color:#3f653b;border:1px solid #b9cda8}.alert-error{background:#ffebee;color:#c62828;border:1px solid #ef9a9a}.success-page{text-align:center;padding:48px 24px}.success-icon{display:inline-flex;align-items:center;justify-content:center;min-width:112px;min-height:42px;padding:8px 16px;border-radius:3px;background:#eef5e9;color:var(--leaf);font-size:.95rem;font-weight:700;margin-bottom:24px}.success-title{font-size:1.5rem;font-weight:600;margin-bottom:16px}.success-message{color:var(--gray-600);margin-bottom:32px}.detail-row{display:flex;padding:12px 0;border-bottom:1px solid var(--gray-200)}.detail-label{flex:0 0 120px;font-weight:500;color:var(--gray-600)}.detail-value{flex:1}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.header-content{gap:12px}.header-nav{justify-content:flex-end}.container{padding:16px}.steps{flex-wrap:wrap;gap:8px}.step-divider,.step-label{display:none}.selector-grid{grid-template-columns:repeat(2,1fr)}.home-hero{padding:26px 18px}.home-hero-actions,.center-action{align-items:stretch;flex-direction:column}.home-hero-actions .btn,.center-action .btn{width:100%}.info-grid{grid-template-columns:1fr}.table th,.table td{padding:8px 12px;font-size:.875rem}.detail-row{flex-direction:column;gap:4px}.detail-label{flex:none}.modal{margin:16px}}@media(max-width:480px){.selector-grid{grid-template-columns:repeat(2,1fr)}.btn{padding:11px 16px}.btn-lg{padding:14px 18px}.header{padding:10px 14px}.header-logo-text{font-size:1rem}.header-logo-image{width:44px;height:44px}.header-nav .btn{padding:9px 12px;font-size:.85rem}.card{padding:16px}.steps{justify-content:space-between;padding:8px}.step-number{width:28px;height:28px}.selector-option{min-height:50px;padding:10px 12px}}.calendar{background:#fff;border-radius:var(--radius-md);border:1px solid #dfc6a6;padding:14px}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.calendar-title{font-size:1.125rem;font-weight:600;color:var(--primary-dark)}.calendar-nav-btn{background:#fafafa;border:1px solid #d8d8d8;width:36px;height:36px;border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;color:var(--gray-600);transition:all var(--transition-fast)}.calendar-nav-btn:hover:not(:disabled){background:var(--gray-200);color:var(--gray-800)}.calendar-nav-btn:disabled{opacity:.3;cursor:not-allowed}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px}.calendar-weekday{text-align:center;font-size:.75rem;font-weight:600;color:var(--gray-500);padding:8px 0}.calendar-weekday.sunday{color:var(--danger)}.calendar-weekday.wednesday{color:var(--gray-400)}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:4px;font-size:.875rem;cursor:pointer;transition:all var(--transition-fast);position:relative}.calendar-day.empty{cursor:default}.calendar-day .day-number{font-weight:500}.calendar-day .day-label{font-size:.625rem;position:absolute;bottom:2px}.calendar-day.available{background:#fff;color:var(--primary-dark);border:1px solid #dddddd}.calendar-day.available:hover{background:var(--primary);color:#fff}.calendar-day.unavailable{background:var(--gray-100);color:var(--gray-400);cursor:not-allowed}.calendar-day.closed{background:var(--gray-200);color:var(--gray-500);cursor:not-allowed}.calendar-day.closed .day-label{color:var(--accent)}.calendar-day.selected{background:#6b3a2e!important;color:#fff!important;box-shadow:none}.calendar-day.today{border:2px solid var(--primary)}.calendar-legend{display:flex;justify-content:center;gap:16px;margin-top:16px;font-size:.75rem;color:var(--gray-600)}.legend-item{display:flex;align-items:center;gap:6px}.legend-dot{width:12px;height:12px;border-radius:50%}.legend-dot.available{background:#fff4e5;border:1px solid var(--primary)}.legend-dot.closed{background:var(--gray-200);border:1px solid var(--gray-400)}@media(max-width:480px){.calendar{padding:12px}.calendar-day{font-size:.75rem}.calendar-day .day-label{font-size:.5rem}}.admin-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:1px solid #dfc6a6;padding-bottom:8px;flex-wrap:wrap}.admin-tab{padding:12px 20px;font-size:.9375rem;font-weight:500;border:none;background:transparent;color:var(--gray-600);cursor:pointer;border-radius:3px;transition:all var(--transition-fast)}.admin-tab:hover{background:#fff4e5;color:var(--primary-dark)}.admin-tab.active{background:var(--primary-dark);color:#fff}.email-template-card{padding:20px;background:#fff9ef;border-radius:var(--radius-md);border:1px solid rgba(122,83,52,.14)}.email-template-card h4{color:var(--gray-700)}.email-template-card code{background:#f5ded8;padding:2px 6px;border-radius:4px;font-size:.8rem;margin:0 2px}@media(max-width:768px){.admin-tabs{gap:4px}.admin-tab{padding:10px 14px;font-size:.8125rem}}
