Shitaye-FrontEnd/src/app/globals.css
“kirukib” 93f93eb087 feat(services): spa & gym page, mock selection, logo loading state
- Add /services with Spa-only and Gym-only offerings, filters, add/remove selection
- Selection panel with subtotal and mailto request; mobile sticky bar when items selected
- ShitayeLogoLoader + route loading.tsx with breathe/ring animations in globals.css
- Home: replace full services grid with promo strip linking to /services
- Nav/footer point to /services; include logo assets and map-related components

Made-with: Cursor
2026-03-25 19:54:11 +03:00

206 lines
5.3 KiB
CSS

@import "tailwindcss";
/*
Shitaye Suite Hotel — dark teal · mustard gold · warm gray.
Teal: chrome, links, wordmark accents. Mustard: primary buttons & CTAs. Gray: borders / structure.
*/
:root {
/* —— Brand base —— */
--color-brand-teal: #174746;
--color-brand-teal-hover: #0f3234;
/* Mustard / gold — flat brand swatch (no gradients on CTAs) */
--color-brand-mustard: #d8a23a;
--color-brand-mustard-hover: #c4932a;
--color-brand-gray: #bdbbb4;
/* —— Semantic —— */
--color-bg: #f5f4f1;
--color-surface: #ffffff;
--color-surface-muted: #e8e6e2;
--color-iced-mint: #e6ebe9;
--color-navy: var(--color-brand-teal);
--color-text: #1c1c1a;
--color-muted: #5c5a54;
--color-border: #a9a79f;
--color-primary: var(--color-brand-teal);
--color-primary-hover: var(--color-brand-teal-hover);
--color-on-primary: #f4f5f4;
--color-accent: var(--color-brand-mustard);
--color-accent-hover: var(--color-brand-mustard-hover);
--color-accent-soft: #faf6ea;
--color-on-accent: #174746;
--shadow-mustard: 0 3px 14px rgba(216, 162, 58, 0.22);
--shadow-mustard-hover: 0 6px 22px rgba(216, 162, 58, 0.32);
--color-lemon-green: #9cae6b;
--color-success: #174746;
/* Rollgates: hotel name in navbar only */
--font-nav: "Rollgates Victoria", "Cormorant Garamond", Georgia, serif;
/* Avenir everywhere else (Mulish as web fallback) */
--font-heading: "Avenir Next", "Avenir", "Mulish", "Helvetica Neue", Helvetica, Arial, sans-serif;
--font-ui: "Avenir Next", "Avenir", "Mulish", "Helvetica Neue", Helvetica, Arial, sans-serif;
--font-ethiopic: "Noto Sans Ethiopic", "Noto Sans", sans-serif;
}
@theme inline {
--color-background: var(--color-bg);
--color-foreground: var(--color-text);
--font-sans: var(--font-ui);
}
html {
scroll-behavior: smooth;
}
body {
background: var(--color-bg);
color: var(--color-text);
font-family: var(--font-ui);
}
/* Headings site-wide (not navbar) */
.font-heading {
font-family: var(--font-heading);
}
/* Hotel name + main nav chrome only */
.font-nav {
font-family: var(--font-nav);
}
/* Amharic copy — guideline: Addis Abeba Unicode; web substitute: Noto Sans Ethiopic */
.font-ethiopic {
font-family: var(--font-ethiopic);
}
/* Branded grid — soft gold hint + faint teal */
.bg-pattern-brand-gold {
background-color: var(--color-bg);
background-image:
linear-gradient(90deg, rgba(216, 162, 58, 0.1) 1px, transparent 1px),
linear-gradient(rgba(23, 71, 70, 0.045) 1px, transparent 1px);
background-size: 28px 28px;
}
/* Primary CTAs — flat mustard */
.btn-mustard {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 0.35rem;
border-radius: 9999px;
font-weight: 600;
color: var(--color-on-accent);
background-color: var(--color-accent);
box-shadow: var(--shadow-mustard);
transition:
background-color 0.2s ease,
box-shadow 0.2s ease,
transform 0.15s ease;
}
.btn-mustard:hover {
background-color: var(--color-accent-hover);
box-shadow: var(--shadow-mustard-hover);
}
.btn-mustard:active {
transform: translateY(1px);
}
.btn-mustard:disabled {
opacity: 0.55;
cursor: not-allowed;
background-color: var(--color-accent);
box-shadow: none;
}
/* Compact rating / score badges (non-pill) */
.badge-mustard {
display: inline-flex;
align-items: center;
justify-content: center;
border-radius: 0.375rem;
font-weight: 700;
font-size: 0.75rem;
line-height: 1rem;
padding: 0.125rem 0.5rem;
color: var(--color-on-accent);
background-color: var(--color-accent);
box-shadow: 0 1px 3px rgba(216, 162, 58, 0.35);
}
/* Pills / chips — flat soft fill + gold border */
.chip-mustard {
border-radius: 9999px;
border: 1px solid rgba(216, 162, 58, 0.45);
background-color: var(--color-accent-soft);
box-shadow: none;
color: var(--color-primary);
font-weight: 600;
font-size: 0.75rem;
line-height: 1rem;
}
.grain::before {
content: "";
pointer-events: none;
position: fixed;
inset: 0;
opacity: 0.035;
background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
z-index: 50;
}
.card-lift {
transition:
transform 0.35s cubic-bezier(0.22, 1, 0.36, 1),
box-shadow 0.35s ease;
}
.card-lift:hover {
transform: translateY(-4px);
box-shadow:
0 20px 44px rgba(23, 71, 70, 0.12),
0 0 0 1px rgba(216, 162, 58, 0.16);
}
@keyframes mock3d-rotate {
from {
transform: rotateY(-12deg) rotateX(4deg);
}
to {
transform: rotateY(12deg) rotateX(4deg);
}
}
.mock3d-plane {
animation: mock3d-rotate 8s ease-in-out infinite alternate;
transform-style: preserve-3d;
}
/* Branded route loader — /services and similar */
@keyframes shitaye-logo-breathe {
0%,
100% {
transform: scale(1);
opacity: 1;
}
50% {
transform: scale(1.045);
opacity: 0.94;
}
}
@keyframes shitaye-logo-ring {
0% {
transform: rotate(0deg);
}
100% {
transform: rotate(360deg);
}
}
.animate-shitaye-logo {
animation: shitaye-logo-breathe 2.4s ease-in-out infinite;
}
.animate-shitaye-ring {
animation: shitaye-logo-ring 12s linear infinite;
}