:root { --bg: #f4efe7; --bg-elevated: rgba(255, 252, 247, 0.86); --bg-strong: #fffaf4; --surface: #ffffff; --surface-muted: #efe6d9; --surface-admin: #f8f5ef; --text: #2f261f; --text-soft: #66574a; --line: rgba(61, 43, 31, 0.12); --line-strong: rgba(61, 43, 31, 0.2); --accent: #b76a47; --accent-strong: #9f5434; --accent-soft: rgba(183, 106, 71, 0.14); --green: #4d695b; --green-soft: rgba(77, 105, 91, 0.16); --shadow-soft: 0 24px 60px rgba(57, 39, 28, 0.10); --shadow-card: 0 18px 36px rgba(57, 39, 28, 0.08); --radius-xl: 32px; --radius-lg: 24px; --radius-md: 18px; --radius-sm: 12px; --content-width: 1180px; --serif: "Iowan Old Style", "Palatino Linotype", "URW Palladio L", Georgia, serif; --sans: "Avenir Next", "Segoe UI", "Helvetica Neue", Arial, sans-serif; } *, *::before, *::after { box-sizing: border-box; } html { scroll-behavior: smooth; } body { margin: 0; background: radial-gradient(circle at top left, rgba(183, 106, 71, 0.12), transparent 30%), linear-gradient(180deg, #f7f2ea 0%, #f1ebe1 100%); color: var(--text); font-family: var(--sans); line-height: 1.6; } a { color: inherit; } img { max-width: 100%; } button, input, select, textarea { font: inherit; } .page-shell { min-height: 100vh; } .site-main { width: min(100%, var(--content-width)); margin: 0 auto; padding: 2.5rem 1.25rem 5rem; } .topbar { border-bottom: 1px solid var(--line); background: rgba(255, 255, 255, 0.5); backdrop-filter: blur(18px); } .topbar-inner, .header-inner { width: min(100%, var(--content-width)); margin: 0 auto; padding: 0.85rem 1.25rem; } .topbar-inner { display: flex; flex-wrap: wrap; gap: 0.75rem 1.2rem; justify-content: space-between; color: var(--text-soft); font-size: 0.92rem; } .site-header { position: sticky; top: 0; z-index: 20; border-bottom: 1px solid var(--line); backdrop-filter: blur(18px); } .site-header-public { background: rgba(248, 243, 235, 0.85); } .site-header-admin { background: rgba(250, 247, 242, 0.96); } .header-inner { display: flex; align-items: center; gap: 1rem; justify-content: space-between; } .brand { display: inline-flex; align-items: center; gap: 0.85rem; text-decoration: none; min-width: 0; } .brand-mark { display: inline-grid; place-items: center; width: 3rem; height: 3rem; border-radius: 999px; background: linear-gradient(135deg, var(--accent) 0%, #d9aa8b 100%); color: white; font-weight: 700; letter-spacing: 0.08em; } .brand-copy { display: flex; flex-direction: column; gap: 0.1rem; min-width: 0; } .brand-copy strong { font-size: 1rem; letter-spacing: 0.02em; } .brand-copy small { color: var(--text-soft); font-size: 0.82rem; } .site-nav { display: flex; align-items: center; flex-wrap: wrap; gap: 0.5rem; } .site-nav a { padding: 0.6rem 0.9rem; border-radius: 999px; text-decoration: none; color: var(--text-soft); transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease; } .site-nav a:hover, .site-nav a:focus-visible, .site-nav a.is-active { background: var(--surface); color: var(--text); transform: translateY(-1px); } .header-actions { display: flex; align-items: center; gap: 0.75rem; flex-wrap: wrap; } .button-primary, .button-secondary, .ghost-button { display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; padding: 0.95rem 1.25rem; border-radius: 999px; border: 1px solid transparent; text-decoration: none; cursor: pointer; transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease; } .button-primary { background: linear-gradient(135deg, var(--accent) 0%, #ca8f71 100%); color: white; box-shadow: 0 16px 34px rgba(183, 106, 71, 0.22); } .button-primary:hover, .button-primary:focus-visible, .button-secondary:hover, .button-secondary:focus-visible, .ghost-button:hover, .ghost-button:focus-visible { transform: translateY(-1px); } .button-secondary { background: rgba(255, 255, 255, 0.72); border-color: var(--line); color: var(--text); } .ghost-button { background: transparent; border-color: var(--line); color: var(--text-soft); } .button-block { width: 100%; } .hero, .page-hero { display: grid; gap: 1.5rem; } .hero { grid-template-columns: minmax(0, 1.2fr) minmax(340px, 0.9fr); align-items: stretch; padding-top: 1rem; } .hero-copy, .hero-panel, .page-hero, .content-card, .feature-card, .module-card, .occasion-card, .trust-card, .availability-card, .faq-card, .table-card, .admin-login-card, .booking-form-shell, .legal-card, .stat-card { border: 1px solid var(--line); background: var(--bg-elevated); backdrop-filter: blur(14px); box-shadow: var(--shadow-card); } .hero-copy, .hero-panel, .page-hero { padding: 2rem; border-radius: var(--radius-xl); } .hero-copy { background: linear-gradient(145deg, rgba(255, 255, 255, 0.88), rgba(244, 236, 224, 0.84)), var(--bg-elevated); } .hero-panel { display: flex; flex-direction: column; justify-content: space-between; background: radial-gradient(circle at top, rgba(183, 106, 71, 0.18), transparent 32%), linear-gradient(180deg, rgba(245, 239, 231, 0.98), rgba(236, 228, 216, 0.92)); } .eyebrow { margin: 0 0 0.75rem; color: var(--accent-strong); font-size: 0.88rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; } h1, h2, h3 { margin: 0 0 0.9rem; line-height: 1.08; font-family: var(--serif); font-weight: 700; } h1 { font-size: clamp(2.4rem, 4vw, 4.7rem); } h2 { font-size: clamp(1.8rem, 3vw, 2.8rem); } h3 { font-size: 1.25rem; } p { margin: 0 0 1rem; color: var(--text-soft); } .hero-text, .page-hero p:last-child { max-width: 42rem; font-size: 1.05rem; } .hero-actions, .section-actions { display: flex; gap: 0.9rem; flex-wrap: wrap; margin-top: 1.5rem; } .hero-panel-top, .hero-panel-bottom { display: flex; justify-content: space-between; gap: 1rem; color: var(--text-soft); } .hero-panel-top strong, .hero-panel-bottom strong { display: block; color: var(--text); } .device-stage { position: relative; min-height: 23rem; display: grid; place-items: center; overflow: hidden; } .device-glow { position: absolute; inset: auto 15% 8% 15%; height: 4rem; border-radius: 999px; background: rgba(183, 106, 71, 0.18); filter: blur(22px); } .device-card { position: absolute; padding: 0.9rem 1rem; border-radius: var(--radius-md); background: rgba(255, 255, 255, 0.84); border: 1px solid rgba(61, 43, 31, 0.08); box-shadow: var(--shadow-card); } .device-card span { display: block; color: var(--text-soft); font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.08em; } .device-card strong { color: var(--text); } .device-card-left { left: 0.75rem; top: 2rem; } .device-card-right { right: 0.75rem; bottom: 3rem; } .device-illustration { position: relative; display: grid; justify-items: center; gap: 0.75rem; } .device-head, .device-body, .device-base, .device-neck { border-radius: 999px; background: linear-gradient(180deg, #352b24 0%, #1f1915 100%); box-shadow: 0 16px 24px rgba(31, 25, 21, 0.18); } .device-head { position: relative; width: 9rem; height: 5rem; border-radius: 2rem; } .device-lens, .device-flash { position: absolute; top: 50%; transform: translateY(-50%); border-radius: 999px; } .device-lens { left: 1.1rem; width: 2.1rem; height: 2.1rem; background: radial-gradient(circle, #5ea2ff 0%, #0f1525 70%); } .device-flash { right: 1.2rem; width: 1rem; height: 1rem; background: linear-gradient(180deg, #f3d9a6 0%, #b76a47 100%); } .device-neck { width: 1rem; height: 2.5rem; } .device-body { width: 8rem; height: 11rem; border-radius: 2.25rem; } .device-base { width: 11rem; height: 1.25rem; } .trust-grid, .feature-card-grid, .occasion-grid, .module-grid, .faq-grid, .stats-grid, .calendar-grid { display: grid; gap: 1rem; } .trust-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); margin-top: 1.75rem; } .trust-card, .feature-card, .module-card, .occasion-card, .faq-card, .stat-card, .legal-card { padding: 1.35rem; border-radius: var(--radius-lg); } .trust-card span, .stat-card span, .summary-line span, .detail-list dt, .table-card-header span, .stack-item span, .availability-card span, .pricing-example-list span, .contact-card span, .small-note { color: var(--text-soft); font-size: 0.92rem; } .trust-card strong, .stat-card strong, .availability-card strong, .pricing-example-list strong, .stack-item strong { color: var(--text); display: block; } .section { margin-top: 1.5rem; padding: 1rem 0; } .section-header { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; margin-bottom: 1rem; } .section-tight { margin-top: 1.1rem; } .section-heading { max-width: 50rem; margin-bottom: 1.4rem; } .split-section, .detail-grid { display: grid; gap: 1.2rem; grid-template-columns: repeat(2, minmax(0, 1fr)); } .content-card, .table-card, .admin-login-card, .booking-form-shell { padding: 1.5rem; border-radius: var(--radius-xl); } .editorial-card { background: linear-gradient(180deg, rgba(255, 252, 247, 0.92), rgba(237, 230, 220, 0.84)); } .emphasis-card { background: linear-gradient(135deg, rgba(183, 106, 71, 0.08), rgba(77, 105, 91, 0.08)), rgba(255, 252, 247, 0.86); } .step-list, .check-list { display: grid; gap: 1rem; padding: 0; margin: 0; list-style: none; } .step-list li { display: grid; grid-template-columns: auto 1fr; gap: 1rem; align-items: start; } .large-step-list li { padding: 1rem 0; border-top: 1px solid var(--line); } .large-step-list li:first-child { border-top: 0; padding-top: 0; } .step-number { display: inline-grid; place-items: center; width: 2.4rem; height: 2.4rem; border-radius: 999px; background: var(--accent-soft); color: var(--accent-strong); font-weight: 700; } .check-list li { position: relative; padding-left: 1.6rem; } .check-list li::before { content: ""; position: absolute; top: 0.55rem; left: 0; width: 0.65rem; height: 0.65rem; border-radius: 999px; background: linear-gradient(135deg, var(--accent) 0%, var(--green) 100%); } .compact-list { gap: 0.75rem; } .availability-list, .pricing-example-list, .stack-list { display: grid; gap: 0.9rem; } .availability-card, .stack-item { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1rem 1.1rem; border-radius: var(--radius-md); } .pricing-example-list article { display: grid; gap: 0.25rem; padding: 1rem; border-radius: var(--radius-md); border: 1px solid var(--line); background: rgba(255, 255, 255, 0.5); } .page-hero { margin-top: 0.6rem; background: linear-gradient(140deg, rgba(255, 255, 255, 0.9), rgba(242, 236, 226, 0.84)); } .booking-card { padding: 1rem; } .booking-form-shell { padding: 0; border: 0; background: transparent; box-shadow: none; } .booking-form { display: grid; gap: 1.25rem; } .stack-form { display: grid; gap: 1rem; } .form-section { padding: 1.35rem; border-radius: var(--radius-lg); border: 1px solid var(--line); background: rgba(255, 255, 255, 0.72); } .form-section-header { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 0.45rem; } .form-step { display: inline-flex; align-items: center; padding: 0.35rem 0.7rem; border-radius: 999px; background: var(--accent-soft); color: var(--accent-strong); font-size: 0.82rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; } .form-help, .form-note { font-size: 0.95rem; } .form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; } .form-grid-two { grid-template-columns: repeat(2, minmax(0, 1fr)); } .form-grid-span { grid-column: 1 / -1; } label { display: grid; gap: 0.5rem; } label span { font-size: 0.93rem; font-weight: 600; color: var(--text); } input, select, textarea { width: 100%; border: 1px solid var(--line-strong); border-radius: var(--radius-sm); padding: 0.9rem 1rem; background: white; color: var(--text); } textarea { resize: vertical; min-height: 7rem; } input:focus, select:focus, textarea:focus, button:focus-visible, a:focus-visible { outline: 2px solid rgba(183, 106, 71, 0.3); outline-offset: 2px; } .booking-summary-card { display: grid; gap: 0.9rem; padding: 1.2rem; border-radius: var(--radius-lg); border: 1px solid var(--line); background: linear-gradient(145deg, rgba(77, 105, 91, 0.08), rgba(183, 106, 71, 0.06)); } .summary-line { display: flex; align-items: center; justify-content: space-between; gap: 1rem; } .summary-line strong { color: var(--text); font-size: 1rem; } .summary-line-total strong { font-size: 1.2rem; } .consent-stack { display: grid; gap: 0.8rem; } .checkbox-row { display: grid; grid-template-columns: auto 1fr; gap: 0.75rem; align-items: start; padding: 1rem 1.1rem; border-radius: var(--radius-md); border: 1px solid var(--line); background: rgba(255, 255, 255, 0.7); } .checkbox-row input { width: 1rem; height: 1rem; margin-top: 0.2rem; } .checkbox-row span { font-weight: 400; color: var(--text-soft); } .checkbox-row a { color: var(--accent-strong); } .contact-card { display: grid; gap: 0.35rem; padding: 1.15rem; border-radius: var(--radius-lg); background: rgba(255, 255, 255, 0.78); border: 1px solid var(--line); } .cta-band { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.5rem 1.75rem; border-radius: var(--radius-xl); border: 1px solid var(--line); background: linear-gradient(145deg, rgba(255, 255, 255, 0.9), rgba(236, 228, 216, 0.86)); box-shadow: var(--shadow-card); } .faq-grid, .legal-section { grid-template-columns: repeat(2, minmax(0, 1fr)); } .legal-section { display: grid; gap: 1rem; } .legal-card a, .contact-card a, .site-footer a { color: var(--accent-strong); text-decoration: none; } .legal-card p:last-child { margin-bottom: 0; } .flash { padding: 1rem 1.1rem; border-radius: var(--radius-md); margin-bottom: 1rem; border: 1px solid; } .flash-success { background: rgba(77, 105, 91, 0.12); border-color: rgba(77, 105, 91, 0.22); color: #2d4b3d; } .flash-error { background: rgba(183, 106, 71, 0.12); border-color: rgba(183, 106, 71, 0.24); color: #7a4129; } .site-footer { margin-top: 3rem; padding: 0 1.25rem 2rem; } .footer-grid { width: min(100%, var(--content-width)); margin: 0 auto; display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 1.25rem; padding: 1.8rem; border-radius: var(--radius-xl); border: 1px solid var(--line); background: rgba(255, 251, 246, 0.76); box-shadow: var(--shadow-card); } .footer-grid h2, .footer-grid h3 { font-family: var(--sans); font-size: 1rem; margin-bottom: 0.8rem; } .footer-grid a, .footer-grid span { display: block; margin-bottom: 0.35rem; color: var(--text-soft); } .theme-admin { background: linear-gradient(180deg, #f7f3ec 0%, #efe8dc 100%); } .admin-section, .admin-login-section { padding-top: 0.5rem; } .admin-login-section { display: grid; place-items: center; min-height: 72vh; } .admin-login-card { width: min(100%, 32rem); } .stats-grid { grid-template-columns: repeat(6, minmax(0, 1fr)); margin: 1rem 0 1.25rem; } .stat-card { border-radius: var(--radius-lg); padding: 1.2rem; } .admin-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: 1.2rem; } .table-card { border-radius: var(--radius-xl); } .table-card-header { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 1rem; } .table-card-header a { color: var(--accent-strong); text-decoration: none; } .table-wrap { overflow-x: auto; border-radius: var(--radius-md); border: 1px solid var(--line); } table { width: 100%; border-collapse: collapse; min-width: 40rem; background: rgba(255, 255, 255, 0.72); } thead { background: rgba(239, 230, 217, 0.64); } th, td { padding: 0.95rem 1rem; text-align: left; border-bottom: 1px solid var(--line); vertical-align: top; } tbody tr:last-child td { border-bottom: 0; } .status-pill { display: inline-flex; align-items: center; padding: 0.35rem 0.7rem; border-radius: 999px; font-size: 0.8rem; font-weight: 700; letter-spacing: 0.04em; } .status-requested { background: rgba(183, 106, 71, 0.14); color: #8d4d31; } .status-reserved { background: rgba(102, 87, 74, 0.14); color: #5e5045; } .status-confirmed, .status-completed { background: rgba(77, 105, 91, 0.14); color: #345243; } .status-cancelled { background: rgba(117, 49, 36, 0.12); color: #7a4132; } .stack-item { border: 1px solid var(--line); background: rgba(255, 255, 255, 0.64); } .empty-state { color: var(--text-soft); margin: 0; } .detail-list { display: grid; gap: 0.9rem; margin: 0; } .detail-list div { display: grid; gap: 0.2rem; padding-bottom: 0.8rem; border-bottom: 1px solid var(--line); } .detail-list div:last-child { border-bottom: 0; padding-bottom: 0; } .detail-list dd { margin: 0; color: var(--text); } .narrow-section { max-width: 72rem; } @media (max-width: 1120px) { .hero, .split-section, .detail-grid, .admin-grid { grid-template-columns: 1fr; } .stats-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } .footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } } @media (max-width: 900px) { .header-inner { flex-direction: column; align-items: stretch; } .site-nav, .header-actions { justify-content: center; } .faq-grid, .legal-section, .trust-grid, .form-grid, .form-grid-two, .calendar-grid { grid-template-columns: 1fr; } .cta-band { flex-direction: column; align-items: stretch; } } @media (max-width: 640px) { .site-main, .topbar-inner, .header-inner, .site-footer { padding-left: 1rem; padding-right: 1rem; } .hero-copy, .hero-panel, .page-hero, .content-card, .table-card, .admin-login-card { padding: 1.25rem; } .hero { grid-template-columns: 1fr; } h1 { font-size: 2.35rem; } h2 { font-size: 1.65rem; } .hero-actions, .section-actions { flex-direction: column; } .button-primary, .button-secondary, .ghost-button { width: 100%; } .stats-grid, .footer-grid { grid-template-columns: 1fr; } .topbar-inner { justify-content: center; } table { min-width: 34rem; } .availability-card, .stack-item, .form-section-header, .hero-panel-top, .hero-panel-bottom { flex-direction: column; align-items: flex-start; } }