summaryrefslogtreecommitdiff
path: root/internal/generator/templates/themes/tropicale/theme.css
blob: dc77be9ab50b40fbe58a589fe8dc0478d7e817d4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
        :root { --sand:#e8c97a; --sky:#38c9d8; --lagoon:#0e7490; --sun:#fbbf24; --coral:#f97316; --dusk:#0a1e2e; --cream:#fef9e7; }
        * { margin:0; padding:0; box-sizing:border-box; }
        body { font-family:'Segoe UI',system-ui,sans-serif; background:var(--dusk);
               color:var(--cream); overflow:hidden; height:100vh; height:100dvh; }
        #three-canvas { position:fixed; top:0; left:0; width:100%; height:100%; z-index:1; }
        .overlay { position:relative; z-index:10; height:100vh; height:100dvh; display:flex; flex-direction:column; }
        header { padding:16px 28px; background:rgba(10,30,46,0.82); backdrop-filter:blur(12px);
                 border-bottom:1px solid rgba(56,201,216,0.3); display:flex; align-items:center; justify-content:space-between; }
        .logo { display:flex; align-items:center; gap:14px; }
        .logo-mark { font-size:2rem; font-weight:800; color:var(--sun); text-shadow:0 0 18px rgba(251,191,36,0.7); }
        .logo-title h1 { font-size:1.5rem; font-weight:700; color:var(--cream); letter-spacing:1px; }
        .logo-title .subtitle { font-size:0.75rem; color:rgba(254,249,231,0.55); margin-top:2px; }
        .logo-title .subtitle a { color:var(--sky); text-decoration:none; }
        .logo-title .subtitle a:hover { text-shadow:0 0 8px var(--sky); }
        .transmit-btn { border:1px solid var(--sky); color:var(--sky); padding:9px 20px;
                        border-radius:20px; text-decoration:none; font-size:0.85rem; transition:all 0.2s; }
        .transmit-btn:hover { background:var(--sky); color:var(--dusk); }
        a.header-feed-link { color:var(--sand); }
        a.header-feed-link:hover { color:var(--cream); }
        .nav-hints { background:rgba(10,30,46,0.65); border-bottom:1px solid rgba(56,201,216,0.18);
                     color:rgba(254,249,231,0.45); padding:5px 28px; display:flex; gap:18px;
                     font-size:0.68rem; flex-wrap:wrap; }
        .nav-hints kbd { background:rgba(56,201,216,0.12); border:1px solid rgba(56,201,216,0.35);
                         color:var(--sky); border-radius:3px; padding:0 5px; margin:0 2px; }
        .content { flex:1; overflow-y:auto; padding:20px 28px;
                   scrollbar-width:thin; scrollbar-color:var(--sky) var(--dusk); }
        .page-nav { display:flex; justify-content:center; margin:14px 0; }
        .page-nav a { border:1px solid var(--lagoon); color:var(--sky); padding:8px 20px;
                      border-radius:20px; text-decoration:none; font-size:0.82rem; }
        .page-nav a:hover { background:var(--sky); color:var(--dusk); }
        .page-nav-footer { flex-shrink:0; padding:8px 28px; display:flex; justify-content:center;
            background:rgba(10,30,46,0.82); backdrop-filter:blur(12px);
            border-top:1px solid rgba(56,201,216,0.3); }
        .post { background:rgba(10,40,60,0.55); border:1px solid rgba(56,201,216,0.22); border-radius:10px;
                padding:20px; margin-bottom:14px; cursor:pointer;
                transition:all 0.25s; backdrop-filter:blur(6px); }
        .post:hover { border-color:var(--sky); box-shadow:0 4px 24px rgba(56,201,216,0.22); transform:translateY(-2px); }
        .post-active { border-color:var(--coral) !important; background:rgba(60,20,10,0.55) !important;
                       box-shadow:0 0 22px rgba(249,115,22,0.35),inset 3px 0 0 var(--coral) !important; }
        .post-header { display:flex; justify-content:space-between; margin-bottom:12px; font-size:0.88rem; }
        .post-time { color:var(--sand); font-family:monospace; font-size:0.8rem; }
        .post-text { line-height:1.65; font-size:0.95rem; }
        .post-text a { color:var(--sky); text-decoration:none; }
        .post-text a:hover { text-shadow:0 0 8px var(--sky); }
        .post-audio { width:100%; margin-top:10px; }
        .post-modal { display:none; position:fixed; inset:0; z-index:100;
                      overflow-y:auto; padding:40px 20px; }
        .post-modal.active { display:block; }
        .modal-inner { max-width:760px; margin:0 auto; background:rgba(10,25,40,0.94);
                       border:1px solid var(--sky); border-radius:12px; backdrop-filter:blur(16px);
                       box-shadow:0 0 60px rgba(56,201,216,0.3); padding:40px; }
        .modal-close { float:right; background:none; border:none; color:var(--sky);
                       font-size:0.9rem; cursor:pointer; letter-spacing:1px; }
        @media(max-width:640px) { .nav-hints{display:none;} header{padding:12px 18px;} .content{padding:14px 18px;} .modal-inner{padding:20px 14px} .transmit-btn{padding-top:11px;padding-bottom:11px;min-height:44px} .modal-close{padding:10px 14px;min-width:44px;min-height:44px;text-align:center} }
        /* Splash screen — tropical sunset gradient with radial sun glow */
        [data-sno-theme="tropicale"] .splash-overlay {
            background:
                radial-gradient(ellipse 55% 40% at 75% 35%, rgba(251,191,36,0.22) 0%, transparent 60%),
                linear-gradient(175deg, #0a1e2e 0%, #0e3a50 30%, #1a5c70 55%, #0e3a50 80%, #0a1e2e 100%);
        }
        [data-sno-theme="tropicale"] .splash-sun-glow {
            position:absolute; right:22%; top:18%; width:clamp(80px,14vw,130px); height:clamp(80px,14vw,130px);
            border-radius:50%; pointer-events:none; z-index:0;
            background:radial-gradient(circle, rgba(251,191,36,0.9) 30%, rgba(249,115,22,0.5) 60%, transparent 80%);
            box-shadow:0 0 60px 30px rgba(251,191,36,0.35);
            animation: splashSunPulse 3.5s ease-in-out infinite;
        }
        @keyframes splashSunPulse { 0%,100%{ opacity:0.85; transform:scale(1); } 50%{ opacity:1; transform:scale(1.06); } }
        [data-sno-theme="tropicale"] .splash-wave-bar {
            position:absolute; bottom:0; left:0; right:0; height:18px;
            background: linear-gradient(90deg, transparent, rgba(56,201,216,0.6), rgba(232,201,122,0.4), rgba(56,201,216,0.6), transparent);
            animation: splashWaveSweep 2.8s ease-in-out infinite;
        }
        @keyframes splashWaveSweep { 0%,100%{ transform:scaleX(1) translateY(0); } 50%{ transform:scaleX(1.04) translateY(-3px); } }
        [data-sno-theme="tropicale"] .splash-title {
            font-size:clamp(1.45rem,4.5vw,2rem); color:var(--cream);
            text-shadow:0 0 24px rgba(251,191,36,0.55);
        }
        [data-sno-theme="tropicale"] .splash-tag { color:var(--sky); letter-spacing:0.2em; }
        [data-sno-theme="tropicale"] .splash-hint { color:rgba(254,249,231,0.88); }
        [data-sno-theme="tropicale"] .splash-inner { position:relative; z-index:2; text-shadow:0 2px 16px rgba(10,30,46,0.9); }